加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – regexp与俄罗斯郎

发布时间:2020-12-13 13:44:42 所属栏目:PHP教程 来源:网络整理
导读:我用 regexp无法解决我的问题. 好的,当我输入: $string = preg_replace("#[name=([a-zA-Z0-9 .-]+)*]#","$name_start $1 $name_end",$string); 一切都很好,除了俄语的情况. 所以,我尝试重新输入这个reg-exp: $string = preg_replace("#[name=([a-zA-Z0-9
我用 regexp无法解决我的问题.

好的,当我输入:

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

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

所以,我尝试重新输入这个reg-exp:

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

但这不起作用,

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

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

但这很疯狂:D

拜托,给我简单的变体

尝试Unicode范围:
'/[x{0410}-x{042F}]/u'  // matches a capital cyrillic letter in the range A to Ya

不要忘记Unicode的/ u标志.

在你的情况下:

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

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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读