php/js漢字正則表達式總結
來源:程序員人生 發布時間:2014-05-03 10:34:14 閱讀次數:2813次
如果我們要匹配中文漢字在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("/^[x{4e00}-x{9fa5}A-Za-z0-9_]+$/u",$str))
- {
- 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("/^[x{4e00}-x{9fa5}A-Za-z0-9_]+$/u",$str))
- {
- 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
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈