php 解析 excel 存储到 mysql 乱码
编码是个很基础的问题,也是大家很容易忽略的问题,写代码之前多多考虑,以后会少很多麻烦。
PHP发展了不少,现在pear用起来很方便,其中就有相关的class来读取Excel文件里面的内容,如果不想使用pear的话,可以考虑使用excel_class.php,google一下,可以找到这个class的source code下载,也能找到基本的example code,用起来很方便。
需要注意的是,从Excel里面读取出来的属于UTF-16LE编码,如果在移动应用中使用excel_class,则需要注意,因为通常手机都是支持UTF-8编码,其中就涉及到编码的转换。
例如我使用
echo $return[Sheet2][0][0];
来显示第1行第1列里面的内容,原本内容是“开始”,使用PHP在web上显示的时候也确实是“开始”,但是查看网页的源代码是
开始
其中&#是为了在网页上显示,24320和22987的十六进制表示则是“开始”的UTF-16LE编码。
那么我们需要做的就是将这个UTF-16LE编码转换为UTF-8编码。
首先打开excel_class.php,找到函数uc2html, 将函数中的代码注释掉,直接将参数返回, 即改函数不做任何操作。
function uc2html($str) {
return $str;
}
接下来使用PHP中提供的函数mb_convert_encoding来将UTF-16LE转换成UTF-8。
echo mb_convert_encoding($return[Sheet2][0][0], 'UTF-8', 'UTF-16LE');
到此,即完成了UTF-16LE到UTF-8的转换。
需要注意的是,从Excel里面读取出来的属于UTF-16LE编码,如果在移动应用中使用excel_class,则需要注意,因为通常手机都是支持UTF-8编码,其中就涉及到编码的转换。
例如我使用
echo $return[Sheet2][0][0];
来显示第1行第1列里面的内容,原本内容是“开始”,使用PHP在web上显示的时候也确实是“开始”,但是查看网页的源代码是
开始
其中&#是为了在网页上显示,24320和22987的十六进制表示则是“开始”的UTF-16LE编码。
那么我们需要做的就是将这个UTF-16LE编码转换为UTF-8编码。
首先打开excel_class.php,找到函数uc2html, 将函数中的代码注释掉,直接将参数返回, 即改函数不做任何操作。
function uc2html($str) {
return $str;
}
Unicode是"UTF-16LE",我可以通过:
mb_convert_encoding($str, "UTF-16LE", "UTF-8")
或者
iconv("UTF-8", "UTF-16LE", $str)
将UTF-8转换为Unicode。
相关文档:
一、导入数据
1、确定
数据库默认编码,比如编码
为gbk,将读入途径编码同样设为gbk,命令为:
set names gbk;
2、source
d:/20080613.sql 导入数据。验证
数据库
中的数据是否存在乱码。
3、如果仍然存在乱码问题,这时候就要考虑改变导入文件的编 ......
来源 http://e-xia.com/2009/06/rownum-in-mysql/
在工作中碰到这样的问题,在生成报表时第一列要输出top 1, top 2, ... , top 10。而mysql并不自带这样的功能。假设我们有这样的一个表:
mysql> create table tbl (
-> id int primary key,
-> col int
-> );
Query OK, 0 ......
Linux + JDK + Tomcat + MySQL + JDBC 安装手记
一、Red Hat Linux
1.分区
| swap & ......
<?php
//声明数组变量
$arr = array('张三','李四','王五','李明');
//foreach循环遍历数组
foreach($arr as $key => $value){
//注意“$value”后必须要一个空格,否则输出的结果不正确
echo "值$value 的下标为$key<br/ ......
<?php
//声明数组变量
$arr = array(val1 =>'张三',val2 => '李四',val3 => '王五',val4 => '李明',val5 => '周燕妮');
//foreach循环遍历数组
foreach($arr as $key => $value){
//注意“$value”后必须要一个空格,否则输 ......