Home >Backend Development >PHP Tutorial >贪婪模式正则匹配的问题

贪婪模式正则匹配的问题

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2016-06-06 20:47:011111browse

正文:

<code>$content = 'http://www.taobao.com  http://mai.taobao.com http://xx.uz.taobao.com http://yy.uz.taobao.com ';
</code>

期望得到:

<code>[0] => http://xx.uz.taobao.com 
[1] => http://yy.uz.taobao.com
</code>

方法一:

<code>$pat = '/http:\/\/(.*)\.uz\.taobao\.com/is';
</code>

结果:

<code>[0] => http://www.taobao.com  http://mai.taobao.com http://xx.uz.taobao.com http://yy.uz.taobao.com 
</code>

方法二:

<code>$pat = '/http:\/\/(.*)\.uz\.taobao\.com/iUs';
</code>

结果:

<code>[0] => http://www.taobao.com  http://mai.taobao.com http://xx.uz.taobao.com 
[1]=>http://yy.uz.taobao.com 
</code>

请问想得到我期望的值应该怎么写呢?

回复内容:

正文:

<code>$content = 'http://www.taobao.com  http://mai.taobao.com http://xx.uz.taobao.com http://yy.uz.taobao.com ';
</code>

期望得到:

<code>[0] => http://xx.uz.taobao.com 
[1] => http://yy.uz.taobao.com
</code>

方法一:

<code>$pat = '/http:\/\/(.*)\.uz\.taobao\.com/is';
</code>

结果:

<code>[0] => http://www.taobao.com  http://mai.taobao.com http://xx.uz.taobao.com http://yy.uz.taobao.com 
</code>

方法二:

<code>$pat = '/http:\/\/(.*)\.uz\.taobao\.com/iUs';
</code>

结果:

<code>[0] => http://www.taobao.com  http://mai.taobao.com http://xx.uz.taobao.com 
[1]=>http://yy.uz.taobao.com 
</code>

请问想得到我期望的值应该怎么写呢?

<code class="lang-php">$content = 'http://www.taobao.com  http://mai.taobao.com http://xx.uz.taobao.com http://yy.uz.taobao.com ';

preg_match_all('/(https?:\/\/[^.]+\.uz\.taobao\.com)/i', $content, $match);
print_r($match[1]);
</code>

so easy.

<code><?php $content = 'http://www.taobao.com  http://mai.taobao.com http://xx.uz.taobao.com http://yy.uz.taobao.com ';
$pattern = '/http:\/\/[^\/]*?\.uz\.taobao\.com/is';

preg_match_all($pattern, $content, $result);
var_dump($result);

// output
array(1) {
  [0] =>
  array(2) {
    [0] =>
    string(23) "http://xx.uz.taobao.com"
    [1] =>
    string(23) "http://yy.uz.taobao.com"
  }
}
</code>

<code>$content = '<a href="http://www.taobao.com"> sdfasdfasfas sdfsfasf http://mai.taobao.com http://xx.uz.taobao.com http://yy.uz.taobao.com ';
$urls = explode('http://', $content);
array_shift($urls);
$res = [];
foreach($urls as &$url) {
    $item = explode('taobao.com', $url);
    $url = "http://{$item[0]}taobao.com";
    if(preg_match('/uz\.taobao\.com/', $url))
        $res[] = $url;
}
print_r($res);
//Array ( [0] => http://xx.uz.taobao.com [1] => http://yy.uz.taobao.com )
</a></code>
<code>$content = '<a href="http://www.taobao.com"> sdfasdfasfas sdfsfasf http://mai.taobao.com http://xx.uz.taobao.com http://yy.uz.taobao.com ';
preg_match_all('/(http[^taobao]*?uz\.taobao\.com)/i', $content, $match);
print_r($match[1]);
//Array ( [0] => http://xx.uz.taobao.com [1] => http://yy.uz.taobao.com )
</a></code>

另有一个小建议是:一步分成两步,先把URL分拆,再对每个URL做匹配。这样可以增强语义的直观性。

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn