秋水无恨请进,高手请进!关于php的汉字转换Unicode到GBK?

ymwu01 2003-10-08 02:33:21
我用《PHPExcelParserPro3.0》,从*.xls文件导入数据到php的mysql数据库时,如果*.xls文件中有汉字时,导入数据库的汉字是"&#XXXXX;"形式,"&#XXXXX;"在IE中可以自动转换成对应的汉字显示出来,我想请问一下,如何在数据库中插入汉字,而不是"&#XXXXX;"?

我找到了秋水无恨写的下面的代码:

class qswhU{
var $qswhData;
function qswhU($filename="qswhU.php"){
$this->qswhData=file($filename);
}

function decode($str,$pattern=0){
$arr=array("/&#(w+);/iU","/((%ww)+)/i","/%u(w{4,5})/iU");
if(is_integer($pattern)){
if($pattern>=count($arr))die("Invalid Function");
$pattern=$arr[$pattern];
}
return preg_replace_callback($pattern,array($this,"u2gb"),$str);
}

function u2gb($arr){
/******(qiushuiwuhen 2002-8-15)******/
$ret="";$str=$arr[1];
if(preg_match_all("/%w{2}/",$str,$matches)){
for($i=0;$i<count($matches[0]);$i++){
$chr1=hexdec(substr($matches[0][$i],1));
$arr=array("f0","e0","c0","0");
for($j=0;$j<count($arr);$j++)if($chr1>hexdec($arr[$j]))break;
$chr=hexdec(substr($matches[0][$i],1))-hexdec($arr[$j]);
while(++$j<count($arr))$chr=$chr*0x40+(hexdec(substr($matches[0][++$i],1))-0x80);
$str=dechex($chr);
if(strlen($str)==4){
$p=hexdec(substr($str,0,2))-0x4d;
$q=hexdec(substr($str,2))*4;
$ret.=chr(hexdec(substr($this->qswhData[$p],$q,2)));
$ret.=chr(hexdec(substr($this->qswhData[$p],$q+2,2)));
}else
$ret.=chr(hexdec($str));
}
}
else{
if(strtolower($str[0])=="x")
$str=substr($str,1);
else
if(strlen($str)!=4)$str=dechex($str);

if(strlen($str)==4){
$p=hexdec(substr($str,0,2))-0x4d;
$q=hexdec(substr($str,2))*4;
$ret.=chr(hexdec(substr($this->qswhData[$p],$q,2)));
$ret.=chr(hexdec(substr($this->qswhData[$p],$q+2,2)));
}else
$ret.=chr(hexdec($str));
}
return $ret;
}

}

//----------------------------------------------------------

调用方法:

$qswh=new qswhU("qswhU.php");//如果文件名是qswhU.php,可省参数
echo "<xmp>不带参数(默认过滤为:&#[num];):";
//&#后面的数字是"23548",对应的汉字是“导”
echo "n".$qswh->decode("&#[数字];");

输出结果:

输出结果是“n$#23548”,而不是“导”字。

//----------------------------------------------------------

请问秋水无恨我错在什么地方了呢?
...全文
73 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
zalvsa 2003-10-13
  • 打赏
  • 举报
回复
copy PHP\DLLS下的iconv.dll到system32下。
eagle_gui 2003-10-10
  • 打赏
  • 举报
回复
很久不见秋水JJ了,奇怪.

嫁人了?
ymwu01 2003-10-08
  • 打赏
  • 举报
回复
不好意思,我没装libiconv!
装好后再试一下!
再一次谢谢您的帮助!
ymwu01 2003-10-08
  • 打赏
  • 举报
回复
非常感谢您的帮助!:)

请问:

我现在用的php版本是4.3.3,php手册上说只要4.0.5以上的版本就会支持iconv()函数,可我刚才测试时,提示的信息说:Fatal error: Call to undefined function: iconv() ,这是为什么呢?
xizi2002 2003-10-08
  • 打赏
  • 举报
回复
秋水无恨很长时间不在web版块了.
这才是高手...
indeed 2003-10-08
  • 打赏
  • 举报
回复
学习,收藏先
xuzuning 2003-10-08
  • 打赏
  • 举报
回复
<?php
/**
* 转换unicode十进制内码为utf-8编码
*/
function u2utf8($c) {
$str="";
if ($c < 0x80) {
$str.=$c;
} else if ($c < 0x800) {
$str.=chr(0xC0 | $c>>6);
$str.=chr(0x80 | $c & 0x3F);
} else if ($c < 0x10000) {
$str.=chr(0xE0 | $c>>12);
$str.=chr(0x80 | $c>>6 & 0x3F);
$str.=chr(0x80 | $c & 0x3F);
} else if ($c < 0x200000) {
$str.=chr(0xF0 | $c>>18);
$str.=chr(0x80 | $c>>12 & 0x3F);
$str.=chr(0x80 | $c>>6 & 0x3F);
$str.=chr(0x80 | $c & 0x3F);
}
return $str;
}

$Text = "23548";
$Text = iconv("UTF-8","GB2312",u2utf8($Text));
echo $Text;

?>

1、你的程序缺少对照表,自然不能得到正确的结果
2、php4.3.1以后的iconv扩展库已经支持UTF-8、GB2312间的转换,所以没有对照表也很容易做到
ymwu01 2003-10-08
  • 打赏
  • 举报
回复
说明:"&#XXXXX;"中"XXXXX"代表5个数字!

21,891

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧