数据表中既有utf8,又有gbk编码,保存的时候很是latin1的格式
2016-11-30 21:20
218 查看
今天在写一个任务是用了之前的别人建的一个数据表,数据格式如下:
查询数据库编码发现是latin1,我又没有权限更改,好吧查询数据库的时候,php操作查询前先设置编码set names utf8;
打印查询结果还是有一部分数据乱码,然后设置编码set names gbk;还是有一部分乱码,对比两次显示的数据,乱码部分互补,合在一起是完整数据;
然后这会才搜索到一个方法,mb_detect_encoding
处理了一下
$e=mb_detect_encoding($v["qname"], array('UTF-8', 'GBK'));
if($e=='UTF-8') {
$result[$k]['qname']=$v["qname"];
}
else {
$result[$k]['qname']=iconv("gbk", "utf-8", $v["qname"]);
}
把gbk的转了一下。
之前对mb_detect_encoding不了解,导致我傻傻的浪费了好长时间。
---------------------------------------------------------------------------------------
latin1的编码对应的是“ISO-8859-1”编码
查询数据库编码发现是latin1,我又没有权限更改,好吧查询数据库的时候,php操作查询前先设置编码set names utf8;
打印查询结果还是有一部分数据乱码,然后设置编码set names gbk;还是有一部分乱码,对比两次显示的数据,乱码部分互补,合在一起是完整数据;
然后这会才搜索到一个方法,mb_detect_encoding
处理了一下
$e=mb_detect_encoding($v["qname"], array('UTF-8', 'GBK'));
if($e=='UTF-8') {
$result[$k]['qname']=$v["qname"];
}
else {
$result[$k]['qname']=iconv("gbk", "utf-8", $v["qname"]);
}
把gbk的转了一下。
之前对mb_detect_encoding不了解,导致我傻傻的浪费了好长时间。
---------------------------------------------------------------------------------------
latin1的编码对应的是“ISO-8859-1”编码
相关文章推荐
- jdbc连接数据库的时候,显示出乱码。所以修改my.ini下的编码格式,把utf-8改为gbk,但是保存的时候出现说my.ini拒绝访问的情况。保存不成功,希望大家能够帮我解决,谢谢!
- 将编码格式为utf8转换为GBK的一个脚本
- MyEclipse默认编码为GBK,修改为UTF8的方法【修改JS编码格式】
- 【编码格式】GBK和UTF8 的区别
- MyEclipse默认编码为GBK,修改为UTF8的方法【修改JS编码格式】
- mysql把latin1编码的中文转成gbk(或utf8)编码
- winform 中 将listview数据 以excel格式导出 保存在可选择的文件夹下 但文件打开的时候有问题
- SQLyog软件里无法插入中文(即由默认的latin1改成UTF8编码格式)
- Avro技术应用_8. 使用 Sqoop 加载数据的时候使用 Avro 格式进行编码 -- 带完善
- MyEclipse默认编码为GBK,修改为UTF8的方法【修改JS编码格式】
- PHP关于GBK格式写入utf8_general_ci 编码mysql数据库乱码的解决办法
- Hibernate+Mysql在向数据库中保存 / 更新数据时设置编码格式
- [置顶] GBK编码数据转码为UTF-8格式
- MySQL 数据编码 latin1 转 UTF8
- php导入到excel-支持utf8和gbk两种编码 格式防乱码
- java中GBK编码格式转成UTF8
- mysql设置了默认编码为utf8,可是往表中插入数据的时候会出错
- 分析:windows下cmd默认的编码是ASCII编码 ,windows的中文环境下编码是GBK 方法一:在保存输出流保存的时候做一个对文字GBK编码,在输出到文件 如下 [python] view
- Java| Java-GBK工程转UTF8工程(批量转换项目文件编码格式)
- java中GBK编码格式转成UTF8