这条正则我再那些正则测试工具里面都是可以正确匹配,为什么放到preg_match_all('/(\@[a-z]+\|[\u4e00-\u9fa5]+\|[A-Z]+\|[a-z]+\|[a-z]+\|[0-9]+)/is',$a)是不行的啊?测试工具里面我选全局搜索是可以的,不选是不行的,是不是这个原因呢?preg_match_all不是就全局搜索的吗?
正则
------解决方案--------------------
正确的写法是:
/(\@[a-z]+\
------解决方案--------------------
[\x{4e00}-\x{9fa5}]+\
------解决方案--------------------
[A-Z]+\
------解决方案--------------------
[a-z]+\
------解决方案--------------------
[a-z]+\
------解决方案--------------------
[0-9]+)/isu
------解决方案--------------------
这个 \u4e00-\u9fa5 是 unicode 编码的中文区间,可见你的测试工具是网页形式的
php 的正则引擎不能识别这种格式,自然也就不能得到正确的结果了
------解决方案--------------------