用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,这只是经验。
在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,这只是经验。
相关文章推荐
- EditPlus快捷键
- PHP-基础3
- PHP json字符串对特殊字符处理(单引号,双引号)
- YII 控制台命令 Action
- php chr() ord()中文截取乱码问题解决方法
- php的ord函数——解决中文字符截断问题
- php:解决简体和繁体字在网页界面显示乱码的函数
- ThinkPHP中RBAC类_ACCESS_LIST显示为空的解决方法
- ThinkPHP多语言功能设置方法
- 详解PHP静态成员函数
- Eclipse PHP 代码无法自动提示函数
- PHP 之 FastCGI 与 mod_php 详解
- 文件打包,下载之使用PHP自带的ZipArchive压缩文件并下载打包好的文件
- php敏感词处理
- PHP刷新输出缓冲
- PHP JSON_ENCODE 不转义中文汉字的方法
- yii命令行下运行控制器【没有验证】
- PHP之CURL模块上传文件
- 如何下载PHP开发文档
- PHP获取MP3时长类