1

我需要从一个数据文件中提取姓名和电子邮件。该文件包含超过 500 行,我想提取这两个信息几乎所有的数据。我想使用 preg_match_all,但我的功能不起作用......

  $chaine =
"  -----------------
11/21/12 16:06:54 tcp static-qvn-qvt-127041
MAIL toto1@web.com
NAME tata1
 -----------------
11/21/12 16:06:54 tcp static-qvn-qvt-127041
MAIL toto2@web.com
NAME tata2
 *  -----------------
11/21/12 16:06:54 tcp static-qvn-qvt-127041
MAIL toto3@web.com
NAME tata3
";

//$chaine =" #76:50#89:1#86:50#49:1#84:22";
$motif="/MAIL([a-z]{2,4}+)NAME([a-z]{2,4}+)/";
preg_match_all($motif,$chaine,$out);
$nb=count($out[0]);
for($i=0;$i<$nb;$i++)
{
    echo $out[0][$i].'<br/>';
}
4

2 回答 2

1

我觉得正则表达式可能对你正在做的事情有点矫枉过正。

为什么不简单地逐行阅读,用空格作为分隔符展开(此处的文档),然后检查第一项是否为“MAIL”,或者是否为“NAME”,然后使用第二项,否则丢弃线?

这是一个示例代码:

foreach(preg_split("/((\r?\n)|(\r\n?))/", $chaine) as $line)
{
    $segments = explode(' ', $line);
    if($segments[0] === "MAIL")
        echo "Found mail " . $segments[1] . "\n";
    elseif($segments[0] === "NAME")
        echo "Found name " . $segments[1] . "\n";
} 
于 2012-11-21T17:16:40.153 回答
1

"s" 修饰符添加对多行的支持。

您的正则表达式将如下所示:

$motif="/MAIL\s*([a-z]{2,4}).*?NAME\s*([a-z]{2,4})/s";
于 2012-11-21T17:16:27.437 回答