一个字符串,我该怎么匹配它里面的网址呢?

2013-09-05 13:21:12 +08:00
 582033
$str='<div>接口了发的撒了http://www.aaa.com/software_zone/2013/0903/2174529.shtml看见了飞洒<img src="http://www.aaa.com/itask_static/expression/t4/appstyle/expression/ext/normal/0b/tootha_org.gif" class="img_emotion"></div>';


如上一个字符串$str,我想匹配里面的http://www.aaa.com/software_zone/2013/0903/2174529.shtml但是不包括图片地址
2362 次点击
所在节点    问与答
6 条回复
lingyired
2013-09-05 13:59:04 +08:00
这个有点难,特别是现在有的url 带中文
vmebeh
2013-09-05 14:07:53 +08:00
[^"](http://[a-zA-Z0-9/\.-_]+)+
好像比较乱
而且“开头的匹配不到,
也许可以试试按不需要的扩展名来匹配
windylcx
2013-09-05 14:07:59 +08:00
理论上任何一个匹配相关的问题都可以用一样东西--正则解决.
vmebeh
2013-09-05 14:10:20 +08:00
如果都是
http://www.aaa.com/software_zone/*的
也可以用
(http://www\.aaa\.com/software_zone/[\d/]+\.shtml)
582033
2013-09-05 14:10:43 +08:00
已经搞定了.THX

preg_replace("/((?<!\")http:\/\/[A-Za-z0-9\.\-]+(\/[A-Za-z0-9\?\&\=;\+!'\(\)\*\-\._~%]*)*)/", '<a>\1</a>', $str)

用了引用替换.直接替换同理.
agassi_yzh
2013-09-05 14:15:15 +08:00
用xpath?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/81404

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX