经测试
将<td xxxx>这行<td xxxx>后面的东西用空格替掉,下面的表达式得到了我要的结果。
$regt = '/<td[^>]*>(([\t ]*\r\n.*)|(.*))<\/td>/i';

解决方案 »

  1.   

    修饰符:
        在正则表达式里面的修饰符可以改变正则的很多特性,使得正则表达式更加适合你的需要(注意:修饰符对于大小写是敏感的,这意味着"e"并不等于"E")。正则表达式里面的修饰符如下: 
    i :如果在修饰符中加上"i",则正则将会取消大小写敏感性,即"a"和"A" 是一样的。 
    m:默认的正则开始"^"和结束"$"只是对于正则字符串如果在修饰符中加上"m",那么开始和结束将会指字符串的每一行:每一行的开头就是"^",结尾就是"$"。 
    s:如果在修饰符中加入"s",那么默认的"."代表除了换行符以外的任何字符将会变成任意字符,也就是包括换行符! 
    x:如果加上该修饰符,表达式中的空白字符将会被忽略,除非它已经被转义。 
    e:本修饰符仅仅对于replacement有用,代表在replacement中作为PHP代码。 
    A:如果使用这个修饰符,那么表达式必须是匹配的字符串中的开头部分。比如说"/a/A"匹配"abcd"。 
    E:与"m"相反,如果使用这个修饰符,那么"$"将匹配绝对字符串的结尾,而不是换行符前面,默认就打开了这个模式。 
    U:和问号的作用差不多,用于设置"贪婪模式"。
      

  2.   

    MARK ~~~~~~~~~~~
    支持 唠唠叨叨~~~~~~~~
      

  3.   

    我目前用的手册里找不到模式修正符的解说,翻开平时不用的netvt制作的手册,找到了相关答案。netvt的手册里由于例子太少,基本上是属于空白。所以我平时不用,虽然它很新。/s是好用的,可惜。依然匹配不了所以的td
    像下面的格子。共4列
    1.用表达式
    $regt = '/<td[^>]*>(.*)<\/td>/s'; //取一格.
    则只能取到一个列,因为.也包括了 </td><td>等。
    2.用表达式
    $regt = '/<td[^>]*>([^<]*)<\/td>/i'; //取一格.
    则,内容中包括了html标签的格子就被忽略了。3.怎么解决这个问题。如果解决不了就算了,我另想办法迂回。4.我的解决思路表达式能指定开头结尾吗?就是非遇到结尾单词不结束,一遇到结尾单词就结束。
    相当于可以指定单词为开头和结尾吗?因为^标记只能非单个字符。而不能非整个单词。如果能非整个单词,那么问题就解决了。以下是示例html文本。
    <td>
    xx
    <a href=xx>xxx</a>
    xx
    xx
    </td>
    <td>
    77889</td>
      <td>1</td>
      <td>上海</td>
      

  4.   

    <?php
    $s = <<< TEXT
    <td>
    xx
    <a href=xx>xxx</a>
    xx
    xx
    </td>
    <td>
    77889</td>
      <td>1</td>
      <td>上海</td>
    TEXT;
    $p = '#<td.*?>.+?</td>#s';
    preg_match_all($p, $s, $r);
    print_r($r);
    ?>
    Array
    (
        [0] => Array
            (
                [0] => <td>
    xx
    <a href=xx>xxx</a>
    xx
    xx
    </td>
                [1] => <td>
    77889</td>
                [2] => <td>1</td>
                [3] => <td>上海</td>
            ))
      

  5.   


    Character to the left of question  in the expression should match 0 or 1 time. For example "be?" matches "b" and "be" but not "bee".左边的表达式匹配0次或者1次。谢谢。