为什么我的正则表达式返回false?

时间:2014-11-16 07:52:24

标签: php regex

好的,我正在从我的数据库中选择一些已删除的文本并尝试解析电话号码。它在那里,我没有收到任何错误,但var_dump正在返回int 0为什么?这是代码

$query1 = "SELECT adtext, `key`  FROM usedcars WHERE `key` = $x";

    mysqli_query($conn, $query1);

    $link_result = mysqli_query($conn, $query1);
    $result = mysqli_fetch_assoc($link_result);



    //now parse that number

     $phone_number = preg_match("/^((([0-9]{1})*[- .(]*([0-9]{3})[- .)]*[0-9]{3}[- .]*[0-9]{4})+)*$/", $result['adtext']);

     var_dump($phone_number);
    }

顺便说一下,这是遍历db中每一行的循环的一部分。就像我说的那样,它没有抛出错误,只是没有识别数字,所以我认为正则表达式或idk可能有问题。以下是preg_match - ing

的特定文字
    2001 Ford POS in great condition but definitely Im a liar and it will break down before you get home. Fix.Or.Repair.Daily that what I always say<br>
<br>
NO Blocked Calls<br>
<br>
I AM IN WASHINGTON D.C / VIRGINIA / MARYLAND Local buyers only<br>
<br>
<b>No warranty</b><br>Forsale by owner<br>
<br>
<b>Accepting first offer</b>
<b>24 hours call  <u><b>Call Me ☎ 202-510-5939</b></b></u>


   </div>


     <p class="metaInfoDisplay">Poster's Reputation: 0<br></p>





     <div style="padding-left:2em;">
       &bull; Location: 

         Northern Virginia, ☎ 202-210-5936

     </div>




     <div style="padding-left:2em;"><br />&bull; Post ID: 1234567 washingtondc</div>


       <div id="OtherAdsByThisUser" data-oid="7654321">

请帮助一个慢人!

1 个答案:

答案 0 :(得分:1)

([0-9]?[- .(]*[0-9]{3}[- .)][0-9]{3}[- .][0-9]{4})

没有完全理解你的正则表达式,但你可以尝试这个。虽然需要进行更多的测试。试试这里。

http://regex101.com/r/lZ5mN8/1

由于主播^&,你的正则表达式将无效。它们将匹配行的开头和结尾。我删除了它们并修改了你的正则表达式。