我正在使用preg_match从一段文字中提取基于美国的电话号码的各个部分。我已经可以提取号码了。,但是我想让match[0]只包括电话号码。
问题:我的模式很接近,但是我需要一些帮助来摆脱电话号码之前的任何文本。如何消除前面的字符串"Hey my phone is "
PHP代码
$pattern = '/.*?(?:1(?:[. -])?)?(?:\((?=\d{3}\)))?([2-9]\d{2})'
.'(?:(?<=\(\d{3})\))? ?(?:(?<=\d{3})[.-])?([2-9]\d{2})'
.'[. -]?(\d{4})(?: (?i:ext)\.? ?(\d{1,5}))?.*?/';;
$subject = 'Hey my phone is 911-628-4539, call me tonight at 9:16:00pm, my room is 122-1001';
preg_match($pattern, $subject, $match);
print_r($match);输出
Array ( [0] => Hey my phone is 911-628-4539 [1] => 911 [2] => 628 [3] => 4539 ) 发布于 2011-10-23 12:48:37
只需删除:.*?
从你的审判官那里。如果你不需要它,为什么要匹配它?
发布于 2011-10-23 12:49:10
你捕捉文本部分,因为你匹配它。是领先的.*?做到了这一点。
要么删除它,要么在它后面添加\K。
https://stackoverflow.com/questions/7866168
复制相似问题