程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php/js漢字正則表達式總結

php/js漢字正則表達式總結

編輯:關於PHP編程

如果我們要匹配中文漢字在php與js中只要利用正則/^[\\x{4e00}-\\x{9fa5}]+$/u,匹配雙字節字符(包括漢字在內):[^/x00-/xff]即可,具體如下

 

js版

匹配中文字符的正則表達式: [/u4e00-/u9fa5]

匹配雙字節字符(包括漢字在內):[^/x00-/xff]

 代碼如下 復制代碼


var reg =  /^[u4e00-u9fa5]+$/;

if(reg.test(str))
{
   alert('漢字的干活');
}

計算字符串的長度(一個雙字節字符長度計2,ASCII字符計1)

String.prototype.len=function(){return this.replace([^/x00-/xff]/g,"aa").length;}

php版

php正則匹配漢字!
/^[x{4e00}-x{9fa5}]+$/u

 代碼如下 復制代碼

 

$action = trim($_GET['action']);
if($action == "sub")
{
    $str = $_POST['dir']; 
    //if(!preg_match("/^[".chr(0xa1)."-".chr(0xff)."A-Za-z0-9_]+$/",$str)) //GB2312漢字字母數字下劃線正則表達式
    if(!preg_match("/^[x{4e00}-x{9fa5}A-Za-z0-9_]+$/u",$str))   //UTF-8漢字字母數字下劃線正則表達式
    { 
        echo "您輸入的[".$str."]含有違法字符"; 
    }
    else
    {
        echo "您輸入的[".$str."]完全合法,通過!"; 
    }
}

當然如果要想字符串全是漢字的GBK2312編碼匹配為:

 代碼如下 復制代碼


$str = "小小子";
if(preg_match("/^[".chr(0xa1)."-".chr(0xff)."]+$/",$str)){
print($str."確實全是漢字");
} else {
print($str."這個真 TMD不全是漢字");
}

uft8編碼正則

$str = "漢字";
if (preg_match("/^[x{4e00}-x{9fa5}]+$/u",$str)) {
print("該字符串全部是中文");
} else {
print("該字符串不全部是中文");
}


 

其實只要了解了各個編碼的高位與低位的開始與結束,那麼自然就可以寫出正則,而且直接是十六位的,有啥困難?呵呵。不過要注意,在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漢字字母數字下劃線正則表達式
    if(!preg_match("/^[x{4e00}-x{9fa5}A-Za-z0-9_]+$/u",$str))   //UTF-8漢字字母數字下劃線正則表達式
    {  
         echo "<font color=red>您輸入的[".$str."]含有違法字符</font>";  
     }
     else
     {
         echo "<font color=green>您輸入的[".$str."]完全合法,通過!</font>";  
     }
}
?>

 

+$/u 的意思:

+ 表示重復1次或多次;
$ 表示匹配末尾;
/ 表示定界符;
u 表示模式字符串被當成 UTF-8;
U 表示第一次匹配後即停止搜索。

要匹配2-4 個,用{2,4}表示。
/^[x{4e00}-x{9fa5}]{2,4}$/u

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved