3

我总是使用preg_match它,它总是工作正常,但今天我试图在两个 html 标签之间获取内容<code: 1>DATA</code>

我有一个问题,我的代码解释了:

function findThis($data){
    preg_match_all("/\<code: (.*?)\>(.*?)\<\/code\>/i",$data,$conditions);
    return $conditions;
}

    // plain text
    // working fine

    $data1='Some text...Some.. Te<code: 1>This is a php code</code>';

    //A text with a new lines
    // Not working..

    $data2='some text..
    some.. te
    <code: 1>
    This is a php code
    ..
    </code>
    ';

    print_r(findThis($data1));

    // OUTPUT
    // [0][0] => <code: 1>This is a php code</code>
    // [1][0] => 1
    // [2][0] => This is a php code

    print_r(findThis($data2));

    //Outputs nothing!
4

1 回答 1

7

这是因为 . PHP 中的字符是除换行符以外的任何内容的通配符。包括换行符在内的示例会中断。您要做的是将“s”标志添加到模式的末尾,这会修改 . 完全匹配所有内容(包括换行符)。

/\<code: (.*?)\>(.*?)\<\/code\>/is

见这里:http ://www.php.net/manual/en/regexp.reference.internal-options.php

于 2012-06-24T23:08:46.723 回答