perl学习(3)模式匹配与正则表达式 |
您所在的位置:网站首页 › 正则匹配空格前几个字符 › perl学习(3)模式匹配与正则表达式 |
一:模式匹配中的特殊字符 1: 点号 . 匹配任何单个字符(换行符\n除外) 2: 反斜线 \ 转义字符,用于特殊符号前,使其失去特殊字符的作用变成普通字符 3: + 匹配该字符前面的字符(单个)至少一次;1次,2次...n次 4: * 匹配该字符前面的字符任意次:0次,1次...n次 5: ? 匹配该字符前面的字符0次或者一次 6: .* 匹配任意字符任意次(换行符除外) 7: {count} 匹配前面的字符count次 8: {min,} 匹配前面的字符至少min次 9: {min,max} 匹配至少min,至多max 10: *? 匹配该字符前面的字符任意次:0次,1次...n次,倾向于短字符,非贪婪量词 11: +? 匹配该字符前面的字符(单个)至少一次;1次,2次...n次,倾向于短字符,非贪婪量词 12: () 模式分组字符 eg:/(perl)+/ #有()匹配模式是perl,没有括号,匹配模式是单个字符l; 1)借助模式分组,可以使用\number的方向引用来引用括号内匹配的内容,n和括号内的组号匹配
2)perl 5.10可以使用\g{number}这种形式的反向引用,n可以为负数
输出: 13: | 或,即匹配左右都可 14: 例子
输出: 二: 字符集 字符集是指一串可能出现的字符集合。通过写在方括号([ ])内来表示。只能用来匹配单个字符,但可以是方括号内列出的任意一个
输出: 1: 可以使用字符 - 进行简写; [0-9]表示0到9十个数字 2: 可以使用脱字符 ^ 匹配字符集外的字符 3: 字符集简写
说明:\d 匹配任意的数字, \w匹配任意的字母数字下划线 ,\s匹配任意的空格,
4: 例子
输出: 问题:test_id = 20010的\w\s+匹配一个字符多个空格;按道理匹配不了啊,但输出匹配成功 5: 常用字符集 /[\dA-Fa-f]+/ :匹配16进制数 /\d\D/ :匹配任意字符 /^\d\D/ :什么字符都不匹配 四: 模式匹配操作符与修饰符 1: 操作符 在前面的介绍与例子中,我们使用 // 来进行匹配(实际上是m//); 模式匹配操作符可以使用任意成对的定界符,当使用斜线作为定界符时,开头的m可以省略 eg:m(fred),m,m{fred},m[fred] m%http://% 2: 修饰符(在操作符后面,其实与操作符的/符号合用) 1)/i 进行模式匹配时,将不区分大小写 2)/s 模式中的点号将匹配包括换行符在内的任意字符(注意与\s区分开来,\s是字符集里匹配任意的空格的简写) 3)/x 忽略空白符,使用/x修饰符可以在模式里面随意加上空白,使其更容易阅读。 五: 锚位 1: ^ 标志字符串的开头 2: $ 标志字符串的末尾,eg:/^\s*$/ 3: /b 指定特定的单词 单词(\w+)锚位,匹配任何单词的收尾 4: /B 非单词锚位,匹配所有/b不能匹配的位置 5: 例子
输出: 六: 绑定操作符=~ 默认情况下,模式匹配的对象的$_,绑定操作符=~用于告诉perl拿右边的模式匹配左边的字符串,而不是匹配$_变量中的字符串
七: 模式串中的变量内插 例如: my $val = "just"; my $val2 = "This is just a test example"; if ($val2 =~ /($val)/) { .... } #正则表达式中的变量内插,if ($val2 =~ /$(val)/)也可。 八: 捕获 把圆括号内的字符串暂时记忆下来的能力,如果有多个圆括号,就有多个捕获。捕获变量都是标量变量,依次为$1,$2...$n 1: 捕获周期 捕获变量通常能存活到下次成功的模式匹配为止,即失败的匹配不会改动上次工程匹配时捕获的内容,而成功时会将它们重置。如果在数行之外使用捕获变量,最好将捕获变量的值复 制到一个一般的变量里
输出: 2: 不匹配模式 一般情况下,模式使用的圆括号都会捕获部分的匹配串到捕获变量中,但若perl正则表达式允许使用括号但不做捕获(不捕获括号),需要在左括号的后面加上问号和冒号(?:)。 3: 命名捕获 管理$1,$2...是比较困难的,尤其是对比较复杂的正则表达式而言。Perl5.10引入了正则表达式命名捕获的概念。 在命名捕获中,捕获结果保存在%+的特殊哈希中;模式加标签的写法是(?PATTERN),访问为$+{LABEL},可使用\g{LABEL}或\k{LABEL}反向引用。 例子:
输出: 4: 自动匹配变量 $&:匹配括号的内容;$`:匹配内容前的字符;$’:匹配内容后的值(包括空格逗号等)
九: 替换 1: s/// 前两个//里是要替换的字符,后两个//里是替换的字符;返回布尔值,替换成功时为真;只替换一个值 2: /g 全局替换;常写在s///后面,/g的斜线省略
输出:
3: 不同的替换界定符 和m//一样,s///操作符也可以使用其他的定界符 1)使用没有左右之分的非成对符号,跟s///一样,只需重复三次即可;eg:s#Barney#Fred# 2)使用有左右之分的成对符号,必须使用两对,一对圈引模式,一对圈引替换模式。圈引模式与圈引替换模式不一定要相同 eg:s{barney}{fred};s[barney][fred];s#barney# 4: 替换修饰符 /g(全局替换) /i,/s,/x (四(2)同) /m 使模式匹配字符串内的换行符 5: 大小写转换
例子:
输出: 十: split操作符 根据指定的分隔符拆开一个字符串,返回子串的列表(即将一个字符串分解为多个)。尤其适用于处理被制表符,冒号,空白或其他符号分割的数据 1: 语法规则 @split = split /separator/,$string or @split = split( /separator/,$string) split会保留开头处的空字段,并省略结尾处的空字段 2: 例子
输出: 说明:多余的冒号会被当成空字符 十一: join函数 将多个字符串片段合并成一个字符串 my $result = join $glue,@pieces; or my $result = join ($glue,@pieces)
输出: 十二: 列表上下文中的m// 一般情况下,模式匹配操作符m//返回的是布尔值,如果在列表上下文中使用模式匹配操作符,将返回所有捕获变量的列表 eg:my $test = "hello,there,neighbor"; my ($first,$second,$third) = ($test = ~ /(\S+) (S+), (S+)/); 大写S是小写s补集。 十三: 命令行执行perl perl -p -i.bak -w -e 's/Randall/Randal/g' fred*.dat
十四:debug perl脚本 1)在程序头添加-d或者在终端perl -d filename.pl;打开debug模式 2)DB l :list the next few lines;p $variable name: 输出变量值; q:quit; r:从子函数中返回; R:再次运行; n:单步执行,不进入子函数(F10) s:单步执行(F11),进入子函数; b:放断点,如b 20 在第二十行放断点 ; c:运行到第一个断点处
|
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |