免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3317 | 回复: 10

这个正则匹配应该怎么写 [复制链接]

求职 : 技术支持/维
论坛徽章:
0
发表于 2010-06-17 15:12 |显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
发表于 2010-06-17 15:25 |显示全部楼层
#!/bin/env perl

use strict;
use warnings;

my $string = qq('first'"second"'third ');
my @ar = $string =~ /(?|'(.*?)'|"(.*?)")/g;
die join("\n", @ar);

求职 : 技术支持/维
论坛徽章:
0
发表于 2010-06-17 15:29 |显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
发表于 2010-06-17 15:31 |显示全部楼层
[oracle@imeg02 perl]$ perl -c i.pl
Sequence (?|...) not recognized in regex; marked by
99超人 发表于 2010-06-17 15:29



5.10才可以。

求职 : 技术支持/维
论坛徽章:
0
发表于 2010-06-17 15:37 |显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
发表于 2010-06-17 15:41 |显示全部楼层
my $string = qq('first'"second"'third ');
my @ar = $string =~ /(['"])(.*?)\1/g;
die join("\n", @ar[grep { $_ % 2 } (0 .. $#ar)]);


单数下标的elem~~~

求职 : 技术支持/维
论坛徽章:
0
发表于 2010-06-17 15:47 |显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
78
双子座
日期:2013-10-15 08:50:09天秤座
日期:2013-10-16 18:02:08白羊座
日期:2013-10-18 13:35:33天蝎座
日期:2013-10-18 13:37:06狮子座
日期:2013-10-18 13:40:31双子座
日期:2013-10-22 13:58:42戌狗
日期:2013-10-22 18:50:04CU十二周年纪念徽章
日期:2013-10-24 15:41:34巨蟹座
日期:2013-10-24 17:14:56处女座
日期:2013-10-24 17:15:30双子座
日期:2013-10-25 13:49:39午马
日期:2013-10-28 15:02:15
发表于 2010-06-17 18:03 |显示全部楼层
\w+不就行了?

论坛徽章:
0
发表于 2010-06-18 07:29 |显示全部楼层
5.80也可以呀,这样试一下:
  1. #!/usr/bin/perl -w
  2. my $str=qq('first'"second"'third');
  3. my @array= $str =~ /(?<=['"])([^'"]+)(?=['"])/g;
复制代码
通过使用lookaround,问题就解决了。@array里的内容即为所求。

论坛徽章:
0
发表于 2010-06-18 07:32 |显示全部楼层
回复 8# yybmsrs

\w+的确是个好点子。这是从内容本身特征,做出的解法。其它从'"入手的,是找的界定符的特征。就看目标内容是不是全由\w+组成了,呵呵。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP