您的位置:首页 > 编程语言 > PHP开发

用PHP正则表达式匹配中文

2015-10-12 16:06 603 查看
转自:http://hsl46346.blog.163.com/blog/static/177640502010427102522815/

在ANSI(gb2312)环 境下

匹配全部的gb2312编 码表的字符:/[“.chr(0xb0).”-“.chr(0xf7).”]+/

单纯匹配汉字而不匹配全角标点:/([“.chr(0xb0).”-“.chr(0xf7).”][“.chr(0xa1).”-“.chr(0xfe).”])/

该表达式能匹配一个中文字符。

匹配全角标点而不匹配汉字:/([“.chr(0xa1).”-“.chr(0xa3).”][“.chr(0xa1).”-“.chr(0xff).”])/

utf-8环 境下中文的匹配

汉字编码范围是0x4e00-0x9fa5,于 是正则式可以这样写:/[\x{4e00}-\x{9fa5}]/u

\x{nnnn}表示字 符的十六进制形式,更多信息请 自己查看php手 册。要特别注意的是模 式修正符u,php手册里这样说:u(PCRE_UTF8)此修正符启用了一个PCRE中与Perl不兼容的额外功能。模式字符串被当成UTF-8。本修正符在Unix下自PHP 4.1.0起可用,在win32下自PHP 4.2.3起可用。自PHP 4.3.5起开始检查模式的UTF-8合法性。这正是正确匹配所必须的。其实也想提醒一下,是utf-8环境使用元字符匹配字符串最好加上修正符u,这只是经验。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: