使用正则表达式从字符串中提取信息

时间:2012-08-03 18:38:09

标签: php regex

我想使用正则表达式提取“软件”及其值“2”的信息信息。请在PHP中查看下面的字符串。

$str = "http://abcfastdirectory.com vs http://www.weblinkstoday.com/detail/link-116406.htm ::-(1)**abcfastdirectory(1)**allows(1)**create(1)**directories(1)**professional(1)**((1)**abcfastdirectory(1)**allows(1)**club(1)**contact(1)**create(2)**details(1)**directories(4)**directory(3)**for(3)**it(1)**our(1)**page(1)**professional(2)**software(2)**"

如何使用PHP中的正则表达式从上面的字符串中提取信息?

4 个答案:

答案 0 :(得分:3)

如果您只是在“软件(2)”之后,则应执行以下操作:

preg_match('/software\((?<value>\d+)\)/', $str, $m);
print $m['value'];

但是,如果您想匹配<word>(<num>)之类的每个部分,您可以使用以下内容:

preg_match_all('/(?<key>\w+)\((?<value>\d+)\)/i', $str, $m);
foreach ($m['key'] as $i => $key) {
     print $key.' => '.$m['value'][$i]."\n";
}

答案 1 :(得分:0)

$software = (int)preg_replace('/.*software\((\d+)\).*/','$1',$str);

答案 2 :(得分:0)

试试这个:

$pattern = '/\*\*software\([0-9]+\)\*\*/';
preg_match($pattern, $str, $matches);

// your value will be stored in $matches[1] 

答案 3 :(得分:0)

您可以尝试这个,看看结果是否符合您的要求:

<?php

$str = "http://abcfastdirectory.com vs http://www.weblinkstoday.com/detail/link-116406.htm ::-(1)**abcfastdirectory(1)**allows(1)**create(1)**directories(1)**professional(1)**((1)**abcfastdirectory(1)**allows(1)**club(1)**contact(1)**create(2)**details(1)**directories(4)**directory(3)**for(3)**it(1)**our(1)**page(1)**professional(2)**software(2)**";

$matches = array();

preg_match_all('#\*\*(.*?)\((\d+)\)\*\*#',$str,$matches, PREG_SET_ORDER );

print_r($matches);