如果我們要匹配中文漢字在php與js中只要利用正則/^[//x{4e00}-//x{9fa5}]+$/u,匹配雙字節(jié)字符(包括漢字在內(nèi)):[^/x00-/xff]即可,具體如下
js版
匹配中文字符的正則表達(dá)式: [/u4e00-/u9fa5]
匹配雙字節(jié)字符(包括漢字在內(nèi)):[^/x00-/xff]
實(shí)例代碼如下:
- var reg = /^[u4e00-u9fa5]+$/;
- if(reg.test(str))
- {
- alert('漢字的干活');
- }
- 計算字符串的長度(一個雙字節(jié)字符長度計2,ASCII字符計1)
- String.prototype.len=function(){return this.replace([^/x00-/xff]/g,"aa").length;}
php版
php正則匹配漢字!
實(shí)例代碼如下:
- $action = trim($_GET['action']);
- if($action == "sub")
- {
- $str = $_POST['dir'];
- //if(!preg_match("/^[".chr(0xa1)."-".chr(0xff)."A-Za-z0-9_]+$/",$str)) //GB2312漢字字母數(shù)字下劃線正則表達(dá)式
- if(!preg_match("/^[x{4e00}-x{9fa5}A-Za-z0-9_]+$/u",$str)) //UTF-8漢字字母數(shù)字下劃線正則表達(dá)式
- {
- echo "您輸入的[".$str."]含有違法字符";
- }
- else
- {
- echo "您輸入的[".$str."]完全合法,通過!";
- }
- }
當(dāng)然如果要想字符串全是漢字的GBK2312編碼匹配為:
- $str = "小小子";
- if(preg_match("/^[".chr(0xa1)."-".chr(0xff)."]+$/",$str)){
- print($str."確實(shí)全是漢字");
- } else {
- print($str."這個真 TMD不全是漢字");
- }
- uft8編碼正則
- $str = "漢字";
- if (preg_match("/^[x{4e00}-x{9fa5}]+$/u",$str)) {
- print("該字符串全部是中文");
- } else {
- print("該字符串不全部是中文");
- }
其實(shí)只要了解了各個編碼的高位與低位的開始與結(jié)束,那么自然就可以寫出正則,而且直接是十六位的,有啥困難?呵呵。不過要注意,在php里面,表示十六位是用的x。
gbk,gb2312的例子:
- <?php
- $action = trim($_GET['action']);
- if($action == "sub")
- {
- $str = $_POST['dir'];
- //if(!preg_match("/^[".chr(0xa1)."-".chr(0xff)."A-Za-z0-9_]+$/",$str)) //GB2312漢字字母數(shù)字下劃線正則表達(dá)式
- if(!preg_match("/^[x{4e00}-x{9fa5}A-Za-z0-9_]+$/u",$str)) //UTF-8漢字字母數(shù)字下劃線正則表達(dá)式
- {
- echo "<font color=red>您輸入的[".$str."]含有違法字符</font>";
- }
- else
- {
- echo "<font color=green>您輸入的[".$str."]完全合法,通過!</font>";
- }
- }
- ?>
+$/u 的意思:
+ 表示重復(fù)1次或多次;
$ 表示匹配末尾;
/ 表示定界符;
u 表示模式字符串被當(dāng)成 UTF-8;
U 表示第一次匹配后即停止搜索。
要匹配2-4 個,用{2,4}表示: /^[x{4e00}-x{9fa5}]{2,4}$/u
新聞熱點(diǎn)
疑難解答