首頁  >  文章  >  後端開發  >  php怎麼只取中文

php怎麼只取中文

藏色散人
藏色散人原創
2021-07-16 11:13:532426瀏覽

php只取中文的方法:先建立一個PHP範例檔;然後透過「preg_match_all('/[\x{4e00}-\x{9fff}] /u', $contens, $content) ;」方法提取字串中所有漢字即可。

php怎麼只取中文

本文操作環境:Windows7系統、PHP7.1版,DELL G3電腦

php怎麼只取中文?

php 提取字串中所有漢字

程式碼如下:

$contens ="assaujms提sd取(*&汉df字99876#$%^&";
//preg_match_all 函数用于执行一个全局正则表达式匹配
preg_match_all('/[\x{4e00}-\x{9fff}]+/u', $contens, $content);
$string = implode('',$content[0]);
echo $string;
//提取汉字

 相關函數介紹:

preg_match_all 函數用於執行一個全域正規表達式匹配。

語法

int preg_match_all ( string $pattern , string $subject [, array &$matches [, int $flags = PREG_PATTERN_ORDER [, int $offset = 0 ]]] )

搜尋 subject 中所有符合 pattern 給定正規表示式的符合結果並且將它們以 flag 指定順序輸出到 matches 中。

在第一個匹配找到後, 子序列繼續從最後一次匹配位置搜尋。

參數說明:

$pattern: 要搜尋的模式,字串形式。

$subject: 輸入字串。

$matches: 多維數組,作為輸出參數輸出所有匹配結果, 數組排序透過flags指定。

$flags:可以結合下面標記使用(注意不能同時使用PREG_PATTERN_ORDER和PREG_SET_ORDER):

PREG_PATTERN_ORDER: 結果排序為$matches[0]保存完整模式的所有匹配, $matches[ 1] 保存第一個子組的所有匹配,以此類推。

PREG_SET_ORDER: 結果排序為$matches[0]包含第一次匹配得到的所有匹配(包含子組), $matches[1]是包含第二次匹配到的所有匹配(包含子組)的數組,以此類推。

PREG_OFFSET_CAPTURE: 如果這個標記被傳遞,每個發現的匹配回傳時會增加它相對目標字串的偏移量。

offset: 通常, 尋找時從目標字串的起始位置開始。可選參數offset用於 從目標字串中指定位置開始搜尋(單位是位元組)。

推薦學習:《PHP影片教學

以上是php怎麼只取中文的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn