沃梦达 / 编程问答 / php问题 / 正文

用于删除多语言字符串上的特殊字符的正则表达式

Regex for removing special characters on a multilingual string(用于删除多语言字符串上的特殊字符的正则表达式)

本文介绍了用于删除多语言字符串上的特殊字符的正则表达式的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

建议用于删除特殊字符的最常见正则表达式似乎是-

preg_replace( '/[^a-zA-Z0-9]/', '', $string );

问题是它还会删除非英文字符。

是否有可删除所有语言上的特殊字符的正则表达式?或者,唯一的解决方案是显式匹配每个特殊字符并将其删除?

推荐答案

您可以改用:

preg_replace('/P{Xan}+/u', '', $string );

p{Xan}是Unicode表中任意字母中的数字或字母。
P{Xan}不是数字或字母。它是[^p{Xan}]

的快捷方式

这篇关于用于删除多语言字符串上的特殊字符的正则表达式的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:用于删除多语言字符串上的特殊字符的正则表达式