>  기사  >  백엔드 개발  >  一个正则的问题

一个正则的问题

WBOY
WBOY원래의
2016-06-23 14:39:40776검색

$string='dj%a3%a3999';if(preg_match('/^[dj]{2}([(\%23)(\%a3\%a3)])((\w)+)$/i', $string,$result)){ print_r($result);}

匹配不上,有什么好的解决方案。


回复讨论(解决方案)

你最好讲一下你的需求吧,中间那段看你的正则很乱。

/*需求就是dj一个分组%a3%a3 或者%23 是另外一个分组999是一个分组通过$result获取对应的数据。如:*/$result[0]='dj';$result[1]='%a3%a3';$result[2]='999';

$s = 'dj%a3%a3999';preg_match('/([^%]+)((?:%a3|23)+)(.+)/', $s, $r);print_r($r);
Array ( [0] => dj%a3%a3999 [1] => dj [2] => %a3%a3 [3] => 999 ) 

使用了这个:

$string='dj%a3%a3999';if(preg_match('/^([dj]{2})([%a3]+)(\d{3})$/i', $string,$result)){ print_r($result);}


结果:
Array ( [0] => dj%a3%a3999 [1] => dj [2] => %a3%a3 [3] => 999 )

$s = 'dj%a3%a3999';preg_match('/([^%]+)((?:%a3|23)+)(.+)/', $s, $r);print_r($r);
Array ( [0] => dj%a3%a3999 [1] => dj [2] => %a3%a3 [3] => 999 ) 

如果$s = 'dj%23999';则不行。

使用了这个:

$string='dj%a3%a3999';if(preg_match('/^([dj]{2})([%a3]+)(\d{3})$/i', $string,$result)){ print_r($result);}

[/code]
这个串也需要匹配的:$string='dj%23999';

$s = 'dj%23999';
preg_match('/([^%]+)((?:%(?:a3|23))+)(.+)/', $s, $r);

preg_match('/([^%]+)((?:%a3|%23)+)(.+)/', $s, $r);

正则表达式规则说明中有:
| 运算时如果发生歧义,则需要逐个开列或用括号括起来

显然 (?:%a3|23) 中 % 被结合到了 a3 从而发生了歧义

老大,能不能帮我解释下,我看到有很多的正则前面都加?:我想知道这个有什么意义?

(?:...) 与 (...) 分组作用一样,但结果不出现结果集中

(?:...) 与 (...) 分组作用一样,但结果不出现结果集中

老大,能不能帮我匹配个地址,如:

www.sohu.com,www.baidu.com,www.yahoo.com.n

这样连着的网址最多为9个,其中也可以匹配sohu.com,baidu.com,yahoo.com.cn

(?!(w))(\w+(-\w+)*)(\.(\w+(-\w+)*))*

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
이전 기사:paypal手机网站支付?다음 기사:php数组重组求助