去除方法:使用preg_replace()函數(shù)配合正則表達(dá)式“/[[:punct:]]/i”來查找字符串中的全部英文標(biāo)點(diǎn)符號(hào),并將其替換為空字符即可;語法“preg_replace('/[[:punct:]]/i', '', $str)”。
本教程操作環(huán)境:windows7系統(tǒng)、PHP7.1版、DELL G3電腦
在php中,可以使用preg_replace()函數(shù)配合正則表達(dá)式來去除字符串中的英文標(biāo)點(diǎn)符號(hào)。
只需要用preg_replace()函數(shù)將英文標(biāo)點(diǎn)符號(hào)替換為空字符串即可。
使用到的正則表達(dá)式為:
/[[:punct:]]/i
示例:只去除英文標(biāo)點(diǎn)符號(hào),保留其他字符(包括中文標(biāo)點(diǎn)符號(hào))
<?php header("Content-type:text/html;charset=utf-8"); $str = "12!@78#9$%^56&78*9()0.8,7<>8|3[]8'45"67!【】“45”‘67’"; echo "原字符串:".$str."<br><br>"; $Newstr=preg_replace('/[[:punct:]]/i','',$str); echo "處理后:".$Newstr; ?>
說明
preg_replace() 函數(shù)可以執(zhí)行正則表達(dá)式的搜索和替換。
preg_replace($pattern, $replacement, $subject [, $limit = -1 [, &$count]])
如果 $subject 是一個(gè)數(shù)組,preg_replace() 函數(shù)會(huì)返回一個(gè)數(shù)組,其他情況下返回一個(gè)字符串。
如果函數(shù) preg_replace() 搜索到匹配項(xiàng),則會(huì)返回被替換后的 $subject,否則返回沒有改變的 $subject。preg_replace() 函數(shù)的每個(gè)參數(shù)(除了參數(shù) $limit)都可以是一個(gè)數(shù)組。如果參數(shù) $pattern 和參數(shù) $replacement 都是數(shù)組,那么該函數(shù)將以其鍵名在數(shù)組中出現(xiàn)的順序來進(jìn)行處理。如果發(fā)生錯(cuò)誤,則返回 NULL。
參數(shù) $replacement 中可以包含后向引用 \n 或 $n,語法上首選后者。每個(gè)這樣的引用將被匹配到的第 n 個(gè)捕獲子組捕獲到的文本替換。n 可以是 0-99,\0 和 $0 代表完整的模式匹配文本。
捕獲子組的序號(hào)計(jì)數(shù)方式為:代表捕獲子組的左括號(hào)從左到右,從 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 將會(huì)使 preg_replace() 不能理解你希望的是一個(gè) \1 后向引用緊跟一個(gè)原文 1,還是一個(gè) \11 后向引用后面不跟任何東西。這種情況下解決方案是使用 ${1}1。這創(chuàng)建了一個(gè)獨(dú)立的 $1 后向引用,一個(gè)獨(dú)立的原文 1。
當(dāng)使用被棄用的 e 修飾符時(shí),這個(gè)函數(shù)會(huì)轉(zhuǎn)義一些字符(即:'、"、 和 NULL)然后進(jìn)行后向引用替換。當(dāng)這些完成后請(qǐng)確保后向引用解析完后沒有單引號(hào)或雙引號(hào)引起的語法錯(cuò)誤(比如:'strlen('$1')+strlen("$2")')。確保符合 PHP 的字符串語法,并且符合 eval 語法。因?yàn)樵谕瓿商鎿Q后,引擎會(huì)將結(jié)果字符串作為 php 代碼使用 eval 方式進(jìn)行評(píng)估并將返回值作為最終參與替換的字符串。
推薦學(xué)習(xí):《PHP視頻教程》