程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> php截取字符串並保留完整xml標簽的函數代碼

php截取字符串並保留完整xml標簽的函數代碼

編輯:PHP綜合
復制代碼 代碼如下:
<?php 
    /**
     * author: goosman
     * blog: http://blog.csdn.net/lgg201
     * mail: [email protected]
     */ 

    $str    = '0123456789<a>012</a>0123456789'; 
    function substr_remain_tag($s, $o, $l) { 
        $is_match   = preg_match_all(<<<heredoc 

    #該正則表達式解析xml標簽, 標簽屬性內部支持轉義符"\", 支持對"\"自身和對應引號的轉義 
    <(\w+)             #標簽開始 
        (?:          #屬性列表 
            \s+       #前置空格 
            \w+    #屬性名
            \s*    #屬性名後的空白(為了兼容) 
            =        #屬性名值之間的等號 
            \s*       #屬性值前的空白(為了兼容) 
            (?:         #屬性值(引號處理) 
                "         #雙引號的情況 
                (?: 
                    \\\\\\\\   #吃掉連續兩個轉義符(表示轉義符自身) 

                    \\\\"          #吃掉轉義符接著一個引號(表示轉義的引號) 

                    [^"\\\\]*   #其他字符 
                )* 
                " 

                '       #單引號情況 
                (?: 
                    \\\\\\\\   #吃掉連續兩個轉義符(表示轉義符自身) 

                    \\\\'   #吃掉轉義符接著一個引號(表示轉義的引號) 

                    [^'\\\\]*       #其他字符 
                )* 
                ' 
            ) 
        )* 
    > 
    .*?               #標簽內容 
    </(?1)>     #結束標簽 
    ;x 
    heredoc 
    , $s, $matches, PREG_OFFSET_CAPTURE, $o); 
        if ( $is_match ) { 
            foreach ( $matches[0] as $match ) { 
                $o0 = $match[1]; 
                #標簽左邊界越過截取目標右邊界, 退出 
                if ( $o0 >= $o + $l ) break; 
                $l0 = strlen($match[0]); 
                #標簽右邊界在截取目標右邊界內, 繼續 
                if ( $o0 + $l0 < $o + $l ) continue; 

                #以下為標簽跨邊界處理 
                $l  = $o0 + $l0 - $o; 
                break; 
            } 
        } 
        return substr($s, $o, $l); 
    }  
    echo $str . chr(10); 
    echo substr_remain_tag($str, 0, 20) . chr(10);
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved