How can I extract or preg_replace chinese characters in a string?(如何提取或preg_place字符串中的中文字符?)
本文介绍了如何提取或preg_place字符串中的中文字符?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我当前有一个字符串列表,如下所示
蘋果,香蕉,橙。
榴蓮, 啤梨
鳳爪,排骨,雞排
24個男,2個女,30個老人
我想要做的就是从这些字符串中分解出所有中文和字母数字字符。
如何将,
,
。
/
"
和空格等所有特殊字符替换为-
或_
然后用explode()
LIKE$str = explode("-",$str);
或$str = explode("_",$str);
提取所有汉字?
我目前有这样的RegEx
if(/^S[u0391-uFFE5 w]+S$/.test(value)).....
我将其修改为
$str = preg_replace("/^S[x{0391}-x{FFE5} w]+s+S$/u", "-", $str);
但似乎没有起作用.
在线示例:https://www.regex101.com/r/qR8aA6/1
编辑:我的预期输出(第一个字符串):
首先应替换为
蘋果-香蕉-橙-
或蘋果_香蕉_橙_
然后我可以用$str = explode("-",$str);
使它们最终变成:
Array
(
[0] => 蘋果
[1] => 香蕉
[2] => 橙
)
推荐答案
您似乎想要这样的东西,
$txt = <<<EOT
蘋果,香蕉,橙。
榴蓮, 啤梨
鳳爪,排骨,雞排
24個男,2個女,30個老人
EOT;
echo preg_replace('~[^p{L}p{N}
]+~u', '-', $txt);
输出:
蘋果-香蕉-橙-
榴蓮-啤梨
鳳爪-排骨-雞排
24個男-2個女-30個老人
DEMO
说明:
p{L}
匹配来自任何语言的任何种类的字母。p{N}
匹配任何脚本中的任何种类的数字字符。- 将所有内容放入求反的字符类将执行相反的操作。
这篇关于如何提取或preg_place字符串中的中文字符?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:如何提取或preg_place字符串中的中文字符?


基础教程推荐
猜你喜欢
- mysqli_insert_id 是否有可能在高流量应用程序中返回 2021-01-01
- 在多维数组中查找最大值 2021-01-01
- 在 Woocommerce 中根据运输方式和付款方式添加费用 2021-01-01
- 在 PHP 中强制下载文件 - 在 Joomla 框架内 2022-01-01
- Libpuzzle 索引数百万张图片? 2022-01-01
- WooCommerce 中选定产品类别的自定义产品价格后缀 2021-01-01
- 通过 PHP SoapClient 请求发送原始 XML 2021-01-01
- 如何在 PHP 中的请求之间持久化对象 2022-01-01
- XAMPP 服务器不加载 CSS 文件 2022-01-01
- 超薄框架REST服务两次获得输出 2022-01-01