如果我們要匹配中文漢字在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