這篇文章主要介紹“php如何將非中文字母去掉”,在日常操作中,相信很多人在php如何將非中文字母去掉問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”php如何將非中文字母去掉”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
成都創(chuàng)新互聯(lián)公司專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站制作、成都做網(wǎng)站、外貿(mào)營銷網(wǎng)站建設(shè)、眉縣網(wǎng)絡(luò)推廣、重慶小程序開發(fā)、眉縣網(wǎng)絡(luò)營銷、眉縣企業(yè)策劃、眉縣品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;成都創(chuàng)新互聯(lián)公司為所有大學(xué)生創(chuàng)業(yè)者提供眉縣建站搭建服務(wù),24小時(shí)服務(wù)熱線:028-86922220,官方網(wǎng)址:aaarwkj.com
php將非中文字母去掉的方法:使用preg_replace()函數(shù)配合正則表達(dá)式來搜索字符串中的非中文字母,并將其替換成空字符即可,語法“preg_replace("/[^\x{4E00}-\x{9FFF}]+/u",'', $str)”。
本教程操作環(huán)境:windows7系統(tǒng)、PHP7.1版、DELL G3電腦
在php中,可以使用preg_replace()函數(shù)配合正則表達(dá)式來去掉字符串中的非中文字母。
正則表達(dá)式為:
/[^\x{4E00}-\x{9FFF}]+/u
preg_replace()刪除原理:利用正則表達(dá)式搜索字符串中的非中文字母,并將其替換成空字符''
。
實(shí)現(xiàn)示例:
<?php header('content-type:text/html;charset=utf-8'); $str= '創(chuàng)新互聯(lián)!-=1548'; $pattern = "/[^\x{4E00}-\x{9FFF}]+/u"; echo preg_replace($pattern,'', $str); ?>
說明:preg_replace():
preg_replace() 函數(shù)可以執(zhí)行正則表達(dá)式的搜索和替換,是一個(gè)強(qiáng)大的字符串替換處理函數(shù),該函數(shù)的語法格式如下:
preg_replace($pattern, $replacement, $subject [, $limit = -1 [, &$count]])
參數(shù)說明如下:
$pattern:要搜索的模式,可以使一個(gè)字符串或字符串?dāng)?shù)組;
$replacement:用于替換的字符串或字符串?dāng)?shù)組。如果這個(gè)參數(shù)是一個(gè)字符串,并且 $pattern 是一個(gè)數(shù)組,那么所有的模式都使用這個(gè)字符串進(jìn)行替換。如果 $pattern 和 $replacement 都是數(shù)組,每個(gè) $pattern 使用 $replacement 中對應(yīng)的元素進(jìn)行替換。如果 $replacement 中的元素比 $pattern 中的少,多出來的 $pattern 使用空字符串進(jìn)行替換。
$subject:要進(jìn)行搜索和替換的字符串或字符串?dāng)?shù)組,如果 $subject 是一個(gè)數(shù)組,搜索和替換回在 $subject 的每一個(gè)元素上進(jìn)行, 并且返回值也會是一個(gè)數(shù)組。
$limit:可選參數(shù),每個(gè)模式在每個(gè) $subject 上進(jìn)行替換的最大次數(shù)。默認(rèn)是 -1(無限)。
$count:可選參數(shù),如果指定,將會被填充為完成的替換次數(shù)。
如果 $subject 是一個(gè)數(shù)組,preg_replace() 函數(shù)會返回一個(gè)數(shù)組,其他情況下返回一個(gè)字符串。
如果函數(shù) preg_replace() 搜索到匹配項(xiàng),則會返回被替換后的 $subject,否則返回沒有改變的 $subject。preg_replace() 函數(shù)的每個(gè)參數(shù)(除了參數(shù) $limit)都可以是一個(gè)數(shù)組。如果參數(shù) $pattern 和參數(shù) $replacement 都是數(shù)組,那么該函數(shù)將以其鍵名在數(shù)組中出現(xiàn)的順序來進(jìn)行處理。如果發(fā)生錯誤,則返回 NULL。
參數(shù) $replacement 中可以包含后向引用 \\n 或 $n,語法上首選后者。每個(gè)這樣的引用將被匹配到的第 n 個(gè)捕獲子組捕獲到的文本替換。n 可以是 0-99,\\0 和 $0 代表完整的模式匹配文本。
捕獲子組的序號計(jì)數(shù)方式為:代表捕獲子組的左括號從左到右,從 1 開始數(shù)。如果要在 $replacement 中使用反斜線,必須使用 4 個(gè)("\\\\" 因?yàn)檫@首先是 php 的字符串,經(jīng)過轉(zhuǎn)義后是兩個(gè),再經(jīng)過正則表達(dá)式引擎后才被認(rèn)為是一個(gè)原文反斜線)。
當(dāng)在替換模式下工作并且后向引用后面緊跟著需要是另外一個(gè)數(shù)字(比如:在一個(gè)匹配模式后緊接著增加一個(gè)原文數(shù)字),不能使用 \\1 這樣的語法來描述后向引用。比如,\\11 將會使 preg_replace() 不能理解你希望的是一個(gè) \\1 后向引用緊跟一個(gè)原文 1,還是一個(gè) \\11 后向引用后面不跟任何東西。這種情況下解決方案是使用 ${1}1。這創(chuàng)建了一個(gè)獨(dú)立的 $1 后向引用,一個(gè)獨(dú)立的原文 1。
當(dāng)使用被棄用的 e 修飾符時(shí),這個(gè)函數(shù)會轉(zhuǎn)義一些字符(即:'、"、\ 和 NULL)然后進(jìn)行后向引用替換。當(dāng)這些完成后請確保后向引用解析完后沒有單引號或雙引號引起的語法錯誤(比如:'strlen(\'$1\')+strlen("$2")')。確保符合 PHP 的字符串語法,并且符合 eval 語法。因?yàn)樵谕瓿商鎿Q后,引擎會將結(jié)果字符串作為 php 代碼使用 eval 方式進(jìn)行評估并將返回值作為最終參與替換的字符串。
到此,關(guān)于“php如何將非中文字母去掉”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!
文章標(biāo)題:php如何將非中文字母去掉
分享網(wǎng)址:http://aaarwkj.com/article30/iihcso.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、、網(wǎng)站改版、動態(tài)網(wǎng)站、網(wǎng)站排名、移動網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)