欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

浅谈PHP导入EXCEL资料

程序员文章站 2022-05-28 23:17:59
...
浅谈PHP导入EXCEL文件

PHP导入excel的开源文件有好几个,我用的是phpExcelReader。

方法如下,直接上代码:

$filename = $_FILES ['excel'] ['name'];$tmp_name = $_FILES ['excel'] ['tmp_name'];// 保存上传文件if (move_uploaded_file ( $tmp_name, 'upload/' . $filename )) {    inputExcel ( $filename );}// 调用Readerrequire_once 'reader.php';// 创建 Reader$data = new Spreadsheet_Excel_Reader ();// 设置文本输出编码$data->setOutputEncoding ( 'utf-8' );// 读取Excel文件$data->read ( 'upload/' . $filename );// $data->sheets[0]['numRows']为Excel行数// $data->sheets[0]['numCols'] 为Excel列数for($i = 2; $i sheets[0]['numRows']; $i ++) {    // 从单元格中获取数据    $a = mysql_real_escape_string ( $data->sheets [0] ['cells'] [$i] [1] );    $b = mysql_real_escape_string ( $data->sheets [0] ['cells'] [$i] [2] );    $c = mysql_real_escape_string ( $data->sheets [0] ['cells'] [$i] [3] );    $d = mysql_real_escape_string ( $data->sheets [0] ['cells'] [$i] [4] );}

?

这段代码的功能就是上传一个excel文件并获取其中数据,值得说明的是:

1、excel表格中不要有半角的(小括号)和[中括号],因为它获取数据的时候是直接保存到一个数组,所以其中的(小括号)和[中括号]会影响数组的格式,并引发错误,我的做法是把它们替换成全角的(小括号)和【中括号】。

2、如果要把从excel中取出的值和数据库交互的话,我在这里mysql_real_escape_string (data)直接做了转义,防止执行数据库时因为一些符号引起的错误。

3、当excel中的数据量比较大的时候,在往数据库中插入的时候,注意sql语句的长度,PHP字符串的长度限制与php.ini中的配置和计算机内存有关。

4、$data->setOutputEncoding ( 'utf-8' )可解决中文乱码的问题。

?

浅谈PHP导入EXCEL资料

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

相关文章

相关视频