内容
<a>123456</a>7890234<a>123789</a>
7890234<a>123789</a>
(?!<a.*?)\d+(?!.*<\/a>)
只好在线等了
123789 不也是在 里,难道你是要匹配不在第一个 里出现的字符?
那用字符串处理函数可能可以,找到第一个 ,取头尾位置,再处理字符串。
建议你先讲字符串按回车分隔,对每个子字符串再进行正则匹配,不知道是否符合你的意思
我现在主要是想搞懂 负向零宽断言 的意思,不知哪位高人能写出此正则
没有解决你的问题,但是在解决的过程中遇到了一个奇怪的问题
$str = <<)\d+(?=<\/a>)/',$str,$m);// [0] => 123456preg_match_all('/(?)\d+(?!<\/a>)/',$str,$t1);/*与 或 相邻的数字没有获取到[0] => 2345[1] => 7890234[2] => 23[3] => 78单独测试 123也是只能获取到 23*/$str_space = << 123456 7890234 123789 EOF;preg_match_all('/(?)\d+(?!<\/a>)/',$str_space,$t2);/*而在 或 相邻的数字加一个空格就可以了[0] => 123456[1] => 7890234[2] => 123[3] => 789*/echo "";print_r($m);print_r($t1);print_r($t2);echo "登录后复制
有劳各位了
早上好啊,该问题没办法了吗
只匹配到 123456 是很容易的
你把它删了,剩下的不就是你要的了吗?
$s =<<< TXT<a>123456</a>7890234<a>123789</a>TXT;$p = '#\d+[\r\n]+#';preg_match_all("/[^\r\n]+/", preg_replace($p, '', $s), $m);print_r($m);
Array( [0] => Array ( [0] => 7890234 [1] => <a>123 [2] => 789</a> ))