php正则字符串有中文,php中正则匹配中文汉字

在php中如果你想正则来获取字符串中汉字我们先需要知道页面编码,正则匹配中文汉字根据页面编码不同而略有区别:GBK/GB2312编码:[x80-xff>] 或 [xa1-xff] 而UTF-8编码:[x{4e00}-x{9fa5}] /u 。

 代码如下复制代码

echo (mb_eregi("[x80-xff].","中d文") ? "有" : "无") ."汉字";

echo (mb_eregi("^([x80-xff].) $","中文") ? "全是汉字" : ""); 看一判断全中文字符串函数

以下以PHP为例进行匹配:

 代码如下复制代码

$str = "学习php是一件快乐的事。";

preg_match_all("/[x80-xff] /", $str, $match);

//UTF-8 使用:

//preg_match_all("/[x{4e00}-x{9fa5}] /u", $str, $match);

print_r($match);

?>

输出:

Array

(

[0] => Array

(

[0] => 学习

[1] => 是一件快乐的事。

)

)

正则汉字

 代码如下复制代码

$str = "请问php中的eregi如何匹配汉字";

if (preg_match("/^[".chr(0x80)."-".chr(0xff)."] $/",$str)) {

echo "这是一个纯中文字符串";

} else{

echo "这不是一个纯中文字串";

}

preg_match_all($pat,……)与preg_replace($pat,……)……

preg_match_all("/(汉字) /ism","我是汉字,看你把我怎么着!",$m_a);

了各个编码的高位与低位的开始与结束,那么自然就可以写出正则,而且直接是十六位的,有啥困难?呵呵。不过要注意,在php里面,表示十六位是用的x

我们还可以用该正则表达式来判断是否是gb2312的汉字

 代码如下复制代码

$str = "小小子";

if(preg_match("/^[xb0-xf7][xa0-xfe] $/",$str)){

print($str."确实全是汉字");

} else {

print($str."这个真tc不全是汉字");

}

?>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值