试试这个代码(在线版@ideone.com):
<?php
$data1='疯狂的管道Test';
$data2='睡眠帮手-背景乐Test';
echo preg_replace("/[\x{4e00}-\x{9fa5}]+/u", '', $data1), "\n";
echo preg_replace("/[\x{4e00}-\x{9fa5}]+/u", '', $data2);
// Better use this (credits to Kobi's answer below)
preg_replace("/\p{Han}+/u", '', $data)
我已经^
从正则表达式中删除了,所以我们不再需要str_replace()了。
您的旧正则表达式匹配所有非中文字符,因此preg_replace()
在返回的字符串中只留下中文字符。为了获得最终结果,您必须将找到的汉字替换为空字符串。
preg_replace("/[^\x{4e00}-\x{9fa5}]+/u", '', $data1) // returns 疯狂的管道
str_replace('疯狂的管道', '', $data1); // gives us Test
第二个正则表达式再次匹配所有非中文字符。但是现在,它们不是按顺序排列的!
preg_replace("/[^\x{4e00}-\x{9fa5}]+/u", '', $data2) // returns 睡眠帮手背景乐
而且这个字符串再也找不到$data2
了,因此它不起作用。