我的MySQL (全部是utf8)数据库中有一些带有重音的数据。比如"7hà18H“(法语的意思是早上7点到下午6点)。在我的php脚本中,我将mysql连接编码设置为utf8,当我收集上面的文本"7Hà18H“时,重音在命令行界面中正确显示(因为我在命令行界面中运行脚本)。
然后,在我尝试用以下命令解析表达式之后
preg_match("#[0-9]+H [Àà] [0-9]+H#i", $text);但是正则表达式不匹配。我不明白为什么我尝试了这个表达
preg_match("#[0-9]+H [Àà]#i",$text,$matches)它是有效的,但匹配结果是:
array(1) {
[0]=>
string(4) "7H �"
}用错误的口音!这就是为什么重音后的空格不会被解释为空格,而是之前错误重音的延续?
我都快气疯了。感谢您的帮助
发布于 2015-04-30 11:52:26
最后,我找到了它。
我必须将选项"u“添加到preg_match中,如下所示
preg_match("#[0-9]+H [Àà] [0-9]+#iu",$text,$matches)来告诉preg_match它是utf8字符串的编码。我不知道为什么它不是默认的。也许有人能给出答案。
https://stackoverflow.com/questions/29958499
复制相似问题