亚洲最大看欧美片,亚洲图揄拍自拍另类图片,欧美精品v国产精品v呦,日本在线精品视频免费

  • 站長(zhǎng)資訊網(wǎng)
    最全最豐富的資訊網(wǎng)站

    php字符串怎么只提取中文字符

    兩種方法:1、用preg_match_all()配合正則過(guò)濾字符串,語(yǔ)法“preg_match_all("/[x{4e00}-x{9fff}]+/u","$str",$arr);”;2、用preg_replace()配合正則搜索字符串中的非中文字母,并將其替換成空字符,語(yǔ)法“preg_replace("/[^x{4E00}-x{9FFF}]+/u",'',$str)”。

    php字符串怎么只提取中文字符

    php入門(mén)到就業(yè)線上直播課:進(jìn)入學(xué)習(xí)
    API 文檔、設(shè)計(jì)、調(diào)試、自動(dòng)化測(cè)試一體化協(xié)作工具:點(diǎn)擊使用

    本教程操作環(huán)境:windows7系統(tǒng)、PHP8.1版、DELL G3電腦

    在php中,可以利用以下兩種函數(shù)來(lái)只提取字符串的中文字符

    • preg_replace()函數(shù)

    • preg_match_all()函數(shù)

    方法1:使用preg_match_all()函數(shù)

    preg_match_all()函數(shù)配合正則表達(dá)式“/[x{4e00}-x{9fff}]+/u”可以過(guò)濾字符串,只獲取中文字符。

    會(huì)將匹配的中文字符一個(gè)個(gè)存入數(shù)組中(該數(shù)組由第三個(gè)參數(shù)指定)。

    <?php header("Content-type:text/html;charset=utf-8"); $str = "歡迎4546來(lái)到php這里。zblog,我的?#$%^天呀&())*(&^"; echo $str; preg_match_all("/[x{4e00}-x{9fff}]+/u","$str",$arr); var_dump($arr); ?>

    php字符串怎么只提取中文字符

    然后可以使用join()函數(shù)將結(jié)果值拼接成一個(gè)字符串。

    join('',$arr[0])

    php字符串怎么只提取中文字符

    說(shuō)明:

    1)preg_match_all()函數(shù)

    preg_match_all()函數(shù)會(huì)搜索字符串中所有可以和正則表達(dá)式匹配的結(jié)果

    preg_match_all(pattern,subject,matches,flags,offset)

    參數(shù)說(shuō)明如下:

    • pattern:要搜索的模式,也就是定義好的正則表達(dá)式;
    • subject:要搜索的字符串;
    • matches:可選參數(shù)(多維數(shù)組),用來(lái)存放所有匹配的結(jié)果, 數(shù)組排序通過(guò) $flags 指定;
    • flags:可選參數(shù),可以結(jié)合下面幾個(gè)標(biāo)記使用(注意不能同時(shí)使用 PREG_PATTERN_ORDER 和 PREG_SET_ORDER):
      • PREG_PATTERN_ORDER:結(jié)果排序?yàn)?$matches[0] 保存完整模式的所有匹配,$matches[1] 保存第一個(gè)子組的所有匹配,以此類(lèi)推。
      • PREG_SET_ORDER:結(jié)果排序?yàn)?$matches[0] 包含第一次匹配得到的所有匹配(包含子組), $matches[1] 是包含第二次匹配到的所有匹配(包含子組)的數(shù)組,以此類(lèi)推。
      • PREG_OFFSET_CAPTURE:如果這個(gè)標(biāo)記被傳遞,每個(gè)發(fā)現(xiàn)的匹配返回時(shí)會(huì)增加它相對(duì)目標(biāo)字符串的偏移量。注意這會(huì)改變 $matches 中的每一個(gè)匹配結(jié)果字符串元素,使其成為一個(gè)第 0 個(gè)元素為匹配結(jié)果字符串,第 1 個(gè)元素為匹配結(jié)果字符串在 subject 中的偏移量。
    • offset:可選參數(shù),$offset 用于從目標(biāo)字符串中指定位置開(kāi)始搜索(單位是字節(jié))。

    preg_match_all() 函數(shù)可以返回 pattern 的匹配次數(shù)(可能是 0),如果發(fā)生錯(cuò)誤則返回 FALSE。

    2)join()函數(shù)

    join() 函數(shù)返回一個(gè)由數(shù)組元素組合成的字符串。

    join() 函數(shù)是 implode() 函數(shù)的別名。

    join(separator,array)
    • separator:可選。規(guī)定數(shù)組元素之間放置的內(nèi)容。默認(rèn)是 ""(空字符串)。

    • array:必需。要組合為字符串的數(shù)組。

    返回值:返回一個(gè)由數(shù)組元素組合成的字符串。

    方法2:使用preg_replace()函數(shù)

    preg_match_all()函數(shù)配合正則表達(dá)式“/[^x{4E00}-x{9FFF}]+/u”搜索字符串中的非中文字母,并將其替換成空字符''即可。

    <?php header("Content-type:text/html;charset=utf-8"); $str= 'php中文網(wǎng)!-=1548'; echo $str."<br>"; $pattern = "/[^x{4E00}-x{9FFF}]+/u"; $newstr=preg_replace($pattern,'', $str);preg_match_all("/[x{4e00}-x{9fff}]+/u","$str",$arr); var_dump($newstr); ?>

    php字符串怎么只提取中文字符

    說(shuō)明:preg_replace()

    preg_replace() 函數(shù)可以執(zhí)行正則表達(dá)式的搜索和替換,是一個(gè)強(qiáng)大的字符串替換處理函數(shù),該函數(shù)的語(yǔ)法格式如下:

    preg_replace($pattern, $replacement, $subject [, $limit = -1 [, &$count]])

    參數(shù)說(shuō)明如下:

    • $pattern:要搜索的模式,可以使一個(gè)字符串或字符串?dāng)?shù)組;
    • $replacement:用于替換的字符串或字符串?dāng)?shù)組。如果這個(gè)參數(shù)是一個(gè)字符串,并且 $pattern 是一個(gè)數(shù)組,那么所有的模式都使用這個(gè)字符串進(jìn)行替換。如果 $pattern 和 $replacement 都是數(shù)組,每個(gè) $pattern 使用 $replacement 中對(duì)應(yīng)的元素進(jìn)行替換。如果 $replacement 中的元素比 $pattern 中的少,多出來(lái)的 $pattern 使用空字符串進(jìn)行替換。
    • $subject:要進(jìn)行搜索和替換的字符串或字符串?dāng)?shù)組,如果 $subject 是一個(gè)數(shù)組,搜索和替換回在 $subject 的每一個(gè)元素上進(jìn)行, 并且返回值也會(huì)是一個(gè)數(shù)組。
    • $limit:可選參數(shù),每個(gè)模式在每個(gè) $subject 上進(jìn)行替換的最大次數(shù)。默認(rèn)是 -1(無(wú)限)。
    • $count:可選參數(shù),如果指定,將會(huì)被填充為完成的替換次數(shù)。

    如果 $subject 是一個(gè)數(shù)組,preg_replace() 函數(shù)會(huì)返回一個(gè)數(shù)組,其他情況下返回一個(gè)字符串。

    如果函數(shù) preg_replace() 搜索到匹配項(xiàng),則會(huì)返回被替換后的 $subject,否則返回沒(méi)有改變的 $subject。preg_replace() 函數(shù)的每個(gè)參數(shù)(除了參數(shù) $limit)都可以是一個(gè)數(shù)組。如果參數(shù) $pattern 和參數(shù) $replacement 都是數(shù)組,那么該函數(shù)將以其鍵名在數(shù)組中出現(xiàn)的順序來(lái)進(jìn)行處理。如果發(fā)生錯(cuò)誤,則返回 NULL。

    參數(shù) $replacement 中可以包含后向引用 \n 或 $n,語(yǔ)法上首選后者。每個(gè)這樣的引用將被匹配到的第 n 個(gè)捕獲子組捕獲到的文本替換。n 可以是 0-99,\0 和 $0 代表完整的模式匹配文本。

    推薦學(xué)習(xí):《PHP視頻教程》

    贊(0)
    分享到: 更多 (0)
    網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)