首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

php utf-8编码 正则匹配中文

首先unicode里面 中文的区域的0x4e00-0x9fa5 在java或者js这种已unicode编码处理字符串的编程语言中 /^[\u4e00-\u9fa5]+$/就可以判断一个字符串是否全部为中文...那么php中 字符的编码根据页面而定 页面是gbk的 字符编码就是gbk的 utf-8也同理 之前有一个表达式 “/^[\x80-\xff]+$/” 仅仅可以匹配是否含有非ascll字符 而汉字只是其中一个比较小的区域...不太精确 由于我的页面编码是utf-8的 于是把js的表达式搬到php中来 提示PCRE不支持”\u”和其他乱七八糟的一大堆东西 后来查资料了解到 php的正则有一种叫做字符组的东西 用\x...又提示”\x”表达式后的数字太大 又查了资料 了解到可以使用修正模式”u” 让程序把后面当成unicode字符处理 于是改成了”/^[\x{4e00}-\x{9fa5}]+$/u” 测试成功 所以php...下正则匹配中文的表达式是 “/^[\x{4e00}-\x{9fa5}]+$/u” 这个仅适用于utf-8编码

3.6K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    如何用正则表达式匹配中文

    前几天因为在做学校教务处的爬虫,用php抓取的成绩和课程表竟然返回的是html格式的数据,也是很醉。没办法,干脆用正则匹配吧。因为之前并没有学过正则表达式,只好恶补了一下。...在匹配的过程中遇到了一些问题,特别是在匹配中文的时候,很是蛋疼。下面说一下我的学习成果。 使用php匹配中文的时候不能使用 \w 来匹配,可以使用元字符 ....来粗略匹配中文 精确匹配中文时需要考虑编码环境,gb2312和 utf-8。这两种编码有什么区别呢 ? 最主要的就是gb2312编码的汉字占两个字节,而utf-8编码的汉字占3个字节。...}]{5}/u 千万注意,这个最后面的u一定要加上(如果是使用php的话),否则是无法正常匹配的。...二、通过上面的表达式我们可以匹配一段模糊的中文,那如果我们想要匹配精准的某个字或者词语呢 ?例如,我在做教务处爬虫时,抓取到的成绩不仅仅只是数字,还有优秀、通过、良好等。这种我们总不能漏掉吧?

    1.2K20

    python正则表达式匹配中文(Excel如何根据名字匹配编码)

    这不是在做正则匹配中文时候,编码又一次成了拦路虎,在这儿记录两点。第一,字符串编码。第二,正则匹配中文。 早期编码都用ASCII编码,用一个字节来处理编码。...如大写A编码为65,但处理中文时候,一个字节显然不够,至少两哥字节,还不能和ASCII冲突,,中国制定GB2312编码,把中文编进去。...由于Python源代码也是一个文本文件,所以,当你的源代码中包含中文的时候,在保存源代码时,就需要务必指定保存为UTF-8编码。...关于Python正则表达式匹配中文,其实只要同意编码就行,我电脑用的py2.7,所以字符串前加u,在正则表达式前也加u即可。...u9fa5]+") result=re.findall(pattern,str) # print result.group() for w in result: print w 更加详细正则匹配内容

    1.5K30

    正则匹配中文数字

    正则匹配中文数字 运营导入小说时遇到小麻烦,想要在章节目录前面加一些符号,word等工具搜半天没搜到,就想着用正则匹配试一下, 于是用notepad++试了一下,正则匹配中文数字章节。...表达式为:(第[\u4e00-\u9fa5\u767e\u5343\u96f6]{1,10}章) 追加的内容\1 ---- 笔记 正则匹配中文个位数,\u4e00-\u9fa5 百千零u767e\u5343...如果再其后面出现\1则是代表与第一个小括号中要匹配的内容相同。...注意:\1必须与小括号配合使用 整体实现效果就是在第几章前边加上了一些你想加上的内容,如下图所示,匹配更改之前: 实现后: 实现为第多少章加上###符号,这个例子最大实现千位数,万位数以及以上

    3.6K30

    PHP使用正则表达式匹配中文,有部分匹配不出来的解决办法

    今天在开发的时候有个需要,就是匹配出一条计价公式里的材料文本,示例:[羊脂玉价格]*[羊脂玉重量]+[白金价格]*[白金重量]+[皓石价格]*[皓石重量]+[钻石价格]*1.5*[钻石重量]+[硬金价格...]*1.67*[硬金重量],要匹配出[***_价格],就是中括号内,以_价格结尾的字符串(代表材料的名称),我用的语言是PHP,写了一条正则表达式出来,代码如下: $pattern = "/\\[([^..._价格]+)_价格\\]/"; $res = preg_match_all($pattern, $s, $matches); var_dump($matches); ,前面三个能匹配出来,但“钻石”一直匹配不到...,非常奇怪,后面测试了一下,跟匹配的数量没有关系,因为如果把“钻石”也改成“白金”的话是能匹配出来的,改成“石”字的话也可以匹配出来,根据这种现象判断,感觉有可能是字符集的问题,有可能是默认的字符集中是没有...“钻”这个字的,所以匹配不到,后面搜索了很多网友关于PHP使用正则匹配中文的文章,发现最全面的匹配方式是使用16进制的,换过来后,果然成功了,故分享出来,以飨大家,最终的代码如下: $s = ‘[羊脂玉价格

    86210

    PHP如何正确统计中文字数

    PHP如何正确统计中文字数?...这个是困扰我很久的问题,PHP 中有很多函数可以计算字符串的长度,比如下面的例子,分别使用了 strlen,mb_strlen,mb_strwidth 这个三个函数去测试统计字符串的长度,看看把中文算成几个字节...3 个字节,mb_strlen 不管中文还是英文,都算 1 个字节,而 mb_strwidth 则把中文算成 2 个字节,所以 mb_strwidth 才是我们想要的:中文 2 个字节,英文 1 个字节...同样截取字符串也建议使用 mb_strimwidth,也是按照 中文 2 个字节,英文 1 个字节 方式计算之后的,并且如果字数超过截取的要求,这个函数还可以在最后面自动添加‘...’。...,'utf-8'); 注意,最后添加‘utf-8’编码参数,可以避免中文截取乱码的问题。 ----

    85820

    Postgresql模糊匹配案例(包括中文前后模糊)

    经常被问到为什么模糊匹配不走索引,验证几种情况(Pg9.4.18) 构造测试数据 create table test(id int, info text); insert into test select...); explain (analyze,verbose,timing,costs,buffers) select * from test where info like '%4152%'; 前后模糊中文...规则 对于中文,lc_ctype不能为"C",只有TOKEN分割正确效果才是OK的 在"C"的库中使用有严重性能问题 test01 DB : test06 | pg9002311 | UTF8 |...如果有前后模糊查询需求,并且包含中文,请使用lc_ctype "C"的数据库,同时使用pg_trgm插件的gin索引。 (只有TOKEN分割正确效果才是OK的。...如果有前后模糊查询需求,并且不包含中文,请使用pg_trgm插件的gin索引。 如果有正则表达式查询需求,请使用pg_trgm插件的gin索引。

    2.3K50

    glob:Python中文件名的匹配

    前言 既然在Pathlib库中提到了glob()函数,那么我们就专门用一篇内容讲解文件名的匹配。其实我们有专门的一个文件名匹配库就叫:glob。...不过,glob库的API非常小,但是仅仅应用于文件名的匹配绰绰有余。只要是在实际的项目中需要过滤,或者匹配一组文件,都可以使用该库进行操作。...是用来匹配单字的,比如我们赛选上面1开头的图片文件。示例如下: import glob for name in glob.glob('text/1?....png'): print(name) 运行之后,效果如下: 区间匹配([0-9][a-z][A-Z]) 从上面两个匹配我们看出来,glob库的匹配规则与正则表达式有些相似。...既然它能匹配模糊的,一个或多个字符,那么肯定也可以匹配区间字符。

    40140

    glob:Python中文件名的匹配

    前言既然在Pathlib库中提到了glob()函数,那么我们就专门用一篇内容讲解文件名的匹配。其实我们有专门的一个文件名匹配库就叫:glob。...不过,glob库的API非常小,但是仅仅应用于文件名的匹配绰绰有余。只要是在实际的项目中需要过滤,或者匹配一组文件,都可以使用该库进行操作。...是用来匹配单字的,比如我们赛选上面1开头的图片文件。示例如下:import globfor name in glob.glob('text/1?....png'): print(name)运行之后,效果如下:图片区间匹配(0-9A-Z)从上面两个匹配我们看出来,glob库的匹配规则与正则表达式有些相似。...既然它能匹配模糊的,一个或多个字符,那么肯定也可以匹配区间字符。

    37560

    前端基础-匹配中文(utf-8编码)

    第5章 匹配中文(utf-8编码) 每个字符(中文、英文字母、数字、各种符号、拉丁文、韩文、日文等)都对应着一个Unicode编码。...查看Unicode编码,找到中文的部分,然后获取中文的Unicode编码的区间,就可以用正则匹配了。...前面我们用[a-z]表示小写字母,[0-9]表示数字,这就是一个范围表示,如果有一个数x能够表示第一个中文,有一个数y能够表示最后一个中文,那么[x-y]就可以表示所有的中文了。...中文的Unicode编码从4E00开始,到9FA5结束。 [\u4E00-\u9FA5]这个区间就能够表示中文。...console.log(res);//["你", "好", "世", "界"] 案例二 解决结巴程序 把“今今今天晚晚晚晚晚晚上吃吃吃吃吃吃鸡”字符串换成单字的形式,即“今天晚上吃鸡”; 核心思想:匹配到重复的字符时

    1.4K10
    领券