首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有mysql数据库重音的Php utf8文本在正则表达式中出现错误

带有mysql数据库重音的Php utf8文本在正则表达式中出现错误
EN

Stack Overflow用户
提问于 2015-04-30 11:25:47
回答 1查看 122关注 0票数 3

我的MySQL (全部是utf8)数据库中有一些带有重音的数据。比如"7hà18H“(法语的意思是早上7点到下午6点)。在我的php脚本中,我将mysql连接编码设置为utf8,当我收集上面的文本"7Hà18H“时,重音在命令行界面中正确显示(因为我在命令行界面中运行脚本)。

然后,在我尝试用以下命令解析表达式之后

代码语言:javascript
复制
preg_match("#[0-9]+H [Àà] [0-9]+H#i", $text);

但是正则表达式不匹配。我不明白为什么我尝试了这个表达

代码语言:javascript
复制
preg_match("#[0-9]+H [Àà]#i",$text,$matches)

它是有效的,但匹配结果是:

代码语言:javascript
复制
array(1) {
  [0]=>
  string(4) "7H �"
}

用错误的口音!这就是为什么重音后的空格不会被解释为空格,而是之前错误重音的延续?

我都快气疯了。感谢您的帮助

EN

回答 1

Stack Overflow用户

发布于 2015-04-30 11:52:26

最后,我找到了它。

我必须将选项"u“添加到preg_match中,如下所示

代码语言:javascript
复制
preg_match("#[0-9]+H [Àà] [0-9]+#iu",$text,$matches)

来告诉preg_match它是utf8字符串的编码。我不知道为什么它不是默认的。也许有人能给出答案。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29958499

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档