晴明qm 2015-09-03 10:13 采纳率: 0%
浏览 1701
已采纳

麻烦看一下这一段正则表达式,有一点问题

 \b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%
=~_|]/i

这段正则的功能是匹配URL

这里的\b是为了什么
-a  a前面的- 是什么
-a-z0-9+   后面的一堆&@#\/%?=~_|!:,.;   这些是什么啊。。。。如果是符号匹配的话,不需要加\吗?
* 后的[ ] 又是为了什么,不是已经有*了吗? 
最后的 [ ] 后面的 /i  又是什么?
  • 写回答

3条回答 默认 最新

  • havedream_one 2015-09-03 11:25
    关注

    \b:匹配单词边界,即URL前面是个空格
    /i : 忽略大小写
    -a-z0-9+&@#\/%?=~_|!:,.; : 匹配 “-”,a-z,0-9,“+”,“&”,“@”,“#”,“/”,“%”,“?”,“=”,“~”,“_”,“|”,“!”,“:”,“,”,“.”,“;”

    • 后的[ ] 又是为了什么,不是已经有*了吗? 对于这个,我感觉*可以写成+,表示匹配1次或多次
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?