ksh 정규 표현 식

3456 단어 shellksh
-- Start
정규 표현 식 이 무엇 인지 모 르 거나 잘 모 르 시 면 정규 표현 식 정 수 를 먼저 읽 으 세 요.
ksh 의 정규 표현 식 은 다른 언어 와 차이 가 있 습 니 다. 가장 중요 한 차 이 는 ksh 에서?임의의 문 자 를 대표 합 니 다. * 여러 문 자 를 대표 합 니 다. 그러면 횟수 는 어떻게 일치 합 니까?아래 표 좀 보 세 요.
操作符	            描述
*(exp)              贪婪匹配,匹配任意次
+(exp)              贪婪匹配,匹配 1次或多次
?(exp)              贪婪匹配,匹配 0或1次
{N}(exp)            贪婪匹配,匹配 N 次
{N,M}(exp)          贪婪匹配,匹配 N 到 M 次
@(exp1|exp2|...)    贪婪匹配,匹配 exp1 或 exp2 ...
*-(exp)             非贪婪匹配,匹配任意次
+-(exp)             非贪婪匹配,匹配 1次或多次
?-(exp)             非贪婪匹配,匹配 0或1次
{N}-(exp)           非贪婪匹配,匹配 N 次
{N,M}-(exp)         非贪婪匹配,匹配 N 到 M 次
@-(exp1|exp2|...)	非贪婪匹配,匹配 exp1 或 exp2 ...
!(exp)              匹配非 exp 的任何东西
[:word:]            匹配字母或下划线
\d                  匹配数字,同[[:digit:]]
\D                  匹配非数字,同[![:digit:]]
\s                  匹配空白字符,同[[:space:]]
\S                  匹配非空白字符,同[![:space:]]
\w                  匹配匹配字母或下划线,同[[:word:]]
\W                  匹配非匹配字母或下划线,同[![:word:]]

다음은 정규 표현 식 을 사용 하 는 간단 한 예 입 니 다.
#!/bin/ksh  

################################ 匹配
typeset brithday='2013-06-25';

if [[ ${brithday} = {4}(\d)-{2}(\d)-{2}(\d) ]]; then  
    print "legal date"  
fi  


################################ 替换
typeset str="Zhang yi, zhang er, Zhuang Si, ZHANG WU";
  
# ${xx/pattern/replace} pattern 是个正则表达式,将变量 xx 中 pattern 匹配的字串替换成 replace 指定的字符串,非贪婪模式 
print "\${xx/pattern/replace} : ${str/Z*(\w)/C\1}";

# ${xx//pattern/replace} 同上,贪婪模式 
print "\${xx//pattern/replace} : ${str//Z*(\w)/C\1}";

# ~(+i:pattern) 表示 pattern使用忽略大小写匹配模式
print "\${xx//pattern/replace} : ${str//~(+i:Z*(\w))/C\1}";


# ksh 不支持 行首,行尾,单词边界 正则表达式,下面的方式实现了类似功能
# ${xx/#pattern/replace} pattern 是个正则表达式,从变量 xx 开头查找 pattern 匹配的字串替,如果找到则换成 replace 指定的字符串,非贪婪模式
print "\${xx/#pattern/replace} : ${str/#Z*(\w)/C\1}";

# ${xx/%pattern/replace} pattern 是个正则表达式,查找变量 xx 是否以 pattern 匹配的字串替结尾,如果找到则换成 replace 指定的字符串,非贪婪模式
print "\${xx/%pattern/replace} : ${str/%?(\w)/*}";


################################  删除子串
# ${xx/pattern} pattern 是个正则表达式,删除变量 xx 中 pattern 匹配的子串,非贪婪模式 
print "\${xx/pattern} : ${str/Z*(\w)}";

# ksh 不支持 行首,行尾,单词边界 正则表达式,下面的方式实现了类似功能
# ${xx#pattern} pattern 是个正则表达式,从变量 xx 开头查找 pattern 匹配的字串替,如果找到则删除,非贪婪模式
print "\${xx#pattern} : ${str#Z*(\w)}";

# ${xx##pattern} 同上,贪婪模式
print "\${xx##pattern} : ${str##Z*(\w)}";

# ${xx%pattern} pattern 是个正则表达式,查找变量 xx 是否以 pattern 匹配的字串替结尾,如果找到则删除,非贪婪模式
print "\${xx%pattern} : ${str%W*(\w)}";

# ${xx%%pattern} 同上,贪婪模式
print "\${xx%%pattern} : ${str%%W*(\w)}";

위 에서 소개 한 정규 표현 식 은 영어 와 만 일치 하 는 결함 이 있 습 니 다. 다른 언어 와 일치 하려 면 표준 POSIX 문법 을 사용 할 수 있 습 니 다. 다음 과 같 습 니 다.
元字符(Metacharacter)	匹配(Matches)
[[:alnum:]]	            字母和数字
[[:alpha:]]	            字母
[[:lower:]]	            小写字母
[[:upper:]]	            大写字母
[[:digit:]]	            数字
[[:blank:]]	            空格和制表符
[[:space:]]	            空白字符
[[:graph:]]	            非空白字符
[[:print:]]	            类似[[:graph:]],但是包含空白字符
[[:punct:]]	            标点符号
[[:cntrl:]]	            控制字符
[[:xdigit:]]	        十六进制中容许出现的数字(例如 0-9a-fA-f)
[. xx .]                将 xx 作为一个整体匹配, xx 可以是任何字母
[= e =]                 认为等价,在法语中匹配 e, è, 或 é

-- 더 많은 참조: ksh 훌륭 하 다
-- 성명: 전재 출처 를 밝 혀 주 십시오.
-- Last Updated on 2015-10-10 -- Written by ShangBo on 2015-09-25 -- End

좋은 웹페이지 즐겨찾기