php只取中文的方法:首先創(chuàng)建一個(gè)PHP示例文件;然后通過“preg_match_all('/[x{4e00}-x{9fff}]+/u', $contens, $content);”方法提取字符串中所有漢字即可。
本文操作環(huán)境:Windows7系統(tǒng)、PHP7.1版,DELL G3電腦
php怎么只取中文?
php 提取字符串中所有漢字
代碼如下:
$contens ="assaujms提sd取(*&漢df字99876#$%^&"; //preg_match_all 函數(shù)用于執(zhí)行一個(gè)全局正則表達(dá)式匹配 preg_match_all('/[x{4e00}-x{9fff}]+/u', $contens, $content); $string = implode('',$content[0]); echo $string; //提取漢字
相關(guān)函數(shù)介紹:
preg_match_all 函數(shù)用于執(zhí)行一個(gè)全局正則表達(dá)式匹配。
語法
int preg_match_all ( string $pattern , string $subject [, array &$matches [, int $flags = PREG_PATTERN_ORDER [, int $offset = 0 ]]] )
搜索 subject 中所有匹配 pattern 給定正則表達(dá)式的匹配結(jié)果并且將它們以 flag 指定順序輸出到 matches 中。
在第一個(gè)匹配找到后, 子序列繼續(xù)從最后一次匹配位置搜索。
參數(shù)說明:
$pattern: 要搜索的模式,字符串形式。
$subject: 輸入字符串。
$matches: 多維數(shù)組,作為輸出參數(shù)輸出所有匹配結(jié)果, 數(shù)組排序通過flags指定。
$flags:可以結(jié)合下面標(biāo)記使用(注意不能同時(shí)使用PREG_PATTERN_ORDER和 PREG_SET_ORDER):
PREG_PATTERN_ORDER: 結(jié)果排序?yàn)?matches[0]保存完整模式的所有匹配, $matches[1] 保存第一個(gè)子組的所有匹配,以此類推。
PREG_SET_ORDER: 結(jié)果排序?yàn)?matches[0]包含第一次匹配得到的所有匹配(包含子組), $matches[1]是包含第二次匹配到的所有匹配(包含子組)的數(shù)組,以此類推。
PREG_OFFSET_CAPTURE: 如果這個(gè)標(biāo)記被傳遞,每個(gè)發(fā)現(xiàn)的匹配返回時(shí)會(huì)增加它相對目標(biāo)字符串的偏移量。
offset: 通常, 查找時(shí)從目標(biāo)字符串的開始位置開始。可選參數(shù)offset用于 從目標(biāo)字符串中指定位置開始搜索(單位是字節(jié))。
推薦學(xué)習(xí):《PHP視頻教程》