9

我无法用正则表达式解决我的问题。

好的,当我输入:

$string = preg_replace("#\[name=([a-zA-Z0-9 .-]+)*]#","$name_start $1 $name_end",$string);

一切都很好,除了俄语的情况。

所以,我尝试重新输入这个正则表达式:

$string = preg_replace("#\[name=([a-zA-Z0-9**а-яА-Я** .-]+)*]#","$name_start $1 $name_end",$string);

但这不起作用,

我知道一些想法,只需写:

$string = preg_replace("#\[name=([a-zA-Z0-9йцукенгшщзхъфывапролджэячсмитьбю .-]+)*]#","$name_start $1 $name_end",$string);

但这太疯狂了:D

请给我简单的变体

4

4 回答 4

18

尝试 Unicode 范围:

'/[\x{0410}-\x{042F}]/u'  // matches a capital cyrillic letter in the range A to Ya

不要忘记 Unicode 的 /u 标志。

在你的情况下:

"#\[name=([a-zA-Z0-9\x{0430}-\x{044F}\x{0410}-\x{042F} .-]+)*]#u"

请注意,正则表达式中的 STAR 是多余的。一切都已经被PLUS“吃掉”了。这会做同样的事情:

"#\[name=([a-zA-Z0-9\x{0430}-\x{044F}\x{0410}-\x{042F} .-]+)]#u"
于 2009-10-15T09:19:46.117 回答
7

通用 unicode 脚本(自 pcre 3.3 起受支持)为属性Cyrillic提供了测试。

例如,替换所有既不是西里尔字母也不是(拉丁)数字的字符:

$string = '1a2b3cйdцeуfкбxюy';
echo preg_replace('/[^0-9\p{Cyrillic}]/u', '*', $string);

您可以在http://www.pcre.org/pcre.txt “Unicode 字符属性”下找到该功能的文档。
您必须指定 PCRE8 标志 (u),如http://docs.php.net/reference.pcre.pattern.modifiers中所述

于 2009-10-15T09:30:44.683 回答
0

这个对我有用:

/^[а-яА-Я\p{Cyrillic}0-9\s\-]+$/ 

我已经在包括 Safari 在内的所有浏览器中进行了测试

于 2014-01-29T14:19:09.090 回答
-1

互联网上最常用的字母之一。

这已经有一段时间了,我相信从 php 5.6 开始。

// Filter Chinese and Japanese HAN
if (preg_match("/\p{Han}+/u", " 余TEST杭丽人广播", $match)){echo "CHINESE, JAPANESE ";}
// Filter Cyrilic
if (preg_match("/\p{Cyrillic}/u", "Күңел радиосы ", $match)){echo "RUSSIAN ";}
// Filter Greek
if (preg_match("/\p{Greek}/u", "Πρακτορείο ", $match)){echo "GREEK ";}
// Filter Arabic
if (preg_match("/\p{Arabic}/u", "مشال راډیو", $match)){echo "ARABIC ";}
// Filter Armenian
if (preg_match("/\p{Armenian}/u", "Ազատություն ", $match)){echo "ARMENIAN ";}
// Filter Thai
if (preg_match("/\p{Thai}/u", "สวท.พะเยา", $match)){echo "THAI ";}
// Filter Georgian
if (preg_match("/\p{Georgian}/u", "რადიო თავისუფალი", $match)){echo "GEORGIAN";}

/* Output: */
/* CHINESE, JAPANESE RUSSIAN GREEK ARABIC ARMENIAN THAI GEORGIAN */
于 2021-04-24T18:23:34.537 回答