用正则匹配多行文本
如果有這樣一個(gè)字符串
? ? ? ? ?$var = "src = arr.c build.c eval.c field.c \
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? missing.c msg.c re.c version.c"
用一般的^\w+\s*=\s*.*$只能匹配上面的那句,而下面的那一句就無(wú)法匹配了
方法一:使用的是perl
?
$var = "src = arr.c build.c eval.c field.c \missing.c msg.c re.c version.c";$var =~ m/((^\w+\s*=\s*.*)(\n.*))/; print "$1: ".$1."\n"; print "$2: ".$2."\n"; print "$3: ".$3."\n";?結(jié)果為:
?
?
1: src = arr.c build.c eval.c field.c missing.c msg.c re.c version.c 2: src = arr.c build.c eval.c field.c 3: missing.c msg.c re.c version.c
注:這里能夠匹配成功是因?yàn)閜erl的點(diǎn)號(hào)" ."能夠匹配除了換行符號(hào)之外的字符,然后在加上換行符號(hào)"\n"
?
和任意符號(hào)".*"就把全部匹配完成了
方法二:有的正則引擎把點(diǎn)號(hào)"."解析可以匹配換行符"\n"那可以這樣
?
$var =~ m/((^\w+\s*=\s*[^\n]*)(\n.*))/效果跟剛才的那個(gè)一樣,只是把點(diǎn)號(hào)替換為了"[^\n]",這樣就排除了換行符號(hào)了。
?
?
轉(zhuǎn)載于:https://www.cnblogs.com/pangblog/p/3275789.html
總結(jié)
- 上一篇: 微软将终止免费的条码标签服务
- 下一篇: 【转】android makefile文