求一个正则

WBOY
풀어 주다: 2016-06-23 14:38:05
원래의
981명이 탐색했습니다.

本帖最后由 hlxtg 于 2013-11-25 13:07:52 编辑

$text="如果因为异地恋远的地方 不要觉得寂寞 不寞和思念换http://www.baidu.com来了一份真正的爱 那是别人求之不得的爱http://www.sy.com/hospital/8 
APP下载地址→ →http://dev.sy.com/apps adfasdfasdf
求一个正则

";

只匹配 http://dev.sy.com/....后面不限
但是得顾虑掉login 里面的dev.sy.com...


回复讨论(解决方案)

匹配结果发一下 看不太懂你说虾米

preg_match_all("#(?<=>)http://dev.sy.com/[^<]*#",$text,$match);print_r($match);
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

只在正文里匹配,是这个意思吧?

$text = "如果因为异地恋远的地方 不要觉得寂寞 不寞和思念换<span   style="max-width:90%">http://www.baidu.com</span>来了一份真正的爱 那是别人求之不得的爱<span> http://www.sy.com/hospital/8 </span><span style='font-size:16px;'>新氧美丽社区APP下载地址→ →<span style='color:#E53333;'>http://dev.sy.com/apps</span></span><span style='font-size:16px;color:#E53333;'></span> adfasdfasdf<a href= onclick=\"login('http://dev.sy.com/post/info/post_id/465/tag_id/1?f=1');\"><img title='勇士对战雷霆的了' alt='勇士对战雷霆的了' src=\"http://img.sy.com/post/2013112219/20131122193630295_75.jpg\"    /></a><p>";echo preg_replace('#(?<=>)(http://dev.sy.com/)[^<]*#s', '【$1】', $text);
로그인 후 복사
로그인 후 복사
如果因为异地恋远的地方 不要觉得寂寞 不寞和思念换http://www.baidu.com来了一份真正的爱 那是别人求之不得的爱 http://www.sy.com/hospital/8
新氧美丽社区APP下载地址→ →【http://dev.sy.com/】 adfasdfasdf
勇士对战雷霆的了


对,因为源码中有的有dev.sy.com 但是我只需要匹配页面输出的

preg_match_all("#(?<=>)http://dev.sy.com/[^<]*#",$text,$match);print_r($match);
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

能写一个正则吗,内容中好多这种连接,输出的数组 还得 套上去,直接替换http://dev.sy.com....加上a标签就可以,上午弄了半天没有弄出来

只在正文里匹配,是这个意思吧?

$text = "如果因为异地恋远的地方 不要觉得寂寞 不寞和思念换<span   style="max-width:90%">http://www.baidu.com</span>来了一份真正的爱 那是别人求之不得的爱<span> http://www.sy.com/hospital/8 </span><span style='font-size:16px;'>新氧美丽社区APP下载地址→ →<span style='color:#E53333;'>http://dev.sy.com/apps</span></span><span style='font-size:16px;color:#E53333;'></span> adfasdfasdf<a href= onclick=\"login('http://dev.sy.com/post/info/post_id/465/tag_id/1?f=1');\"><img title='勇士对战雷霆的了' alt='勇士对战雷霆的了' src=\"http://img.sy.com/post/2013112219/20131122193630295_75.jpg\"    /></a><p>";echo preg_replace('#(?<=>)(http://dev.sy.com/)[^<]*#s', '【$1】', $text);
로그인 후 복사
로그인 후 복사
如果因为异地恋远的地方 不要觉得寂寞 不寞和思念换http://www.baidu.com来了一份真正的爱 那是别人求之不得的爱 http://www.sy.com/hospital/8
新氧美丽社区APP下载地址→ →【http://dev.sy.com/】 adfasdfasdf
勇士对战雷霆的了



对,因为源码中有的有dev.sy.com 但是我只需要匹配页面输出的

$search = array('|\<span\sstyle=\'[\w:#;]+\'\>\s*(http://dev.soyoung.com[^\s\< ]+)\s*\<\/span\>|');
로그인 후 복사

匹配结果发一下 看不太懂你说虾米

$search = array('|(http://dev.sy.com[^\s\< ]+)|');
$replace = array('$1');
$text = preg_replace($search, $replace, $text);


preg_match_all("#(?<=>)http://dev.sy.com/[^<]*#",$text,$match);print_r($match);
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

能写一个正则吗,内容中好多这种连接,输出的数组 还得 套上去,直接替换http://dev.sy.com....加上a标签就可以,上午弄了半天没有弄出来

正则不在里面了,你换个函数就行了
echo preg_replace("#(?<=>)http://dev.sy.com/[^<]*#","<a href='$0'>$0</a>",$text);
로그인 후 복사
로그인 후 복사



preg_match_all("#(?<=>)http://dev.sy.com/[^<]*#",$text,$match);print_r($match);
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

能写一个正则吗,内容中好多这种连接,输出的数组 还得 套上去,直接替换http://dev.sy.com....加上a标签就可以,上午弄了半天没有弄出来

正则不在里面了,你换个函数就行了
echo preg_replace("#(?<=>)http://dev.sy.com/[^<]*#","<a href='$0'>$0</a>",$text);
로그인 후 복사
로그인 후 복사

比如:内容中加入下面信息就不能匹配出
了解更戳这里http://dev.sy.com/apps

echo preg_replace("#(?<!['\"(])http://dev.sy.com/[\w\/]*#","<a href='$0'>$0</a>",$text);
로그인 후 복사

ok了 ,谢谢楼上的大神们了!!!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿