PHP 用PHPExcel往数据库导入大量数据

PHP 用PHPExcel往数据库导入大量数据,第1张

1、首先我们准备一个含有数据的Excel表格,表头和数据表中的表字段相对应。

2、在ThinkPHP中引入PHPExcel类库。

3、然后我们编写导入的PHP代码。

4、然后我们编写导出的PHP代码。

5、然后我们进行导出测试发现可以导出即可。

个人感觉 PHPExcel还是很好用的,首先到官方网站http://phpexcel.codeplex.com/下载最近版本的PHPExcel,解压后会发现里面有class、Documentation、Tests三个文件夹和三个txt的日志文件,主要用到的是Class文件,而Tests主要是一些demo示例

下面来介绍一下PHPExcel的简单用法,这里是与数据库连接的:

首先,要包含PHPExcel.PHP

require_once 'Classes/PHPExcel.php' //路径根据自己实际项目的路径进行设置

$objPHPExcel = new PHPExcel() //创建PHPExcel实例

//下面是对MySQL数据库的连接

$conn = mysql_connect("localhost","root","") or die("数据库连接失败!")

mysql_select_db("image",$conn) //连接数据库

mysql_query("set names 'GBK'") //转换字符编码

$sql = mysql_query("select * from test") //查询sql语句

/*--------------设置表头信息------------------*/

$objPHPExcel->setActiveSheetIndex(0)

->setCellValue('A1', 'ID编号')

->setCellValue('B1', '月份')

->setCellValue('C1', '产品一')

->setCellValue('D1', '产品二')

->setCellValue('E1', '产品三')

/*--------------开始从数据库提取信息插入Excel表中------------------*/

$i=2 //定义一个i变量,目的是在循环输出数据是控制行数

while($rs=mysql_fetch_array($sql)){

$rm = iconv("GB2312","UTF-8",$rs[1])//对字符进行编码将数据库里GB2312的中文字符转换成UTF-8格式

$objPHPExcel->setActiveSheetIndex(0)

->setCellValue("A".$i, $rs[0])

->setCellValue("B".$i, $rm)

->setCellValue("C".$i, $rs[2])

->setCellValue("D".$i, $rs[3])

->setCellValue("E".$i, $rs[4])

$i++

}

/*--------------下面是设置其他信息------------------*/

$objPHPExcel->getActiveSheet()->setTitle('Example1') //设置sheet的名称

$objPHPExcel->setActiveSheetIndex(0) //设置sheet的起始位置

$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5') //通过PHPExcel_IOFactory的写函数将上面数据写出来

$objWriter->save(str_replace('.php', '.xls', __FILE__))//设置以什么格式保存,及保存位置

至此,一个完整的将mysql数据库里的信息用PHP导出Excel实例做完,可能在运行的时候会发生一些问题,如中文乱码,表头可能显示不出来,这是因为文件编码格式的原因,将文件编码设置成UTF-8就行了,在此我就不做太多解释了。

<?php

error_reporting(E_ALL)//开启错误

set_time_limit(0)//脚本不超时

date_default_timezone_set('Europe/London')//设置时间

/** Include path **/

set_include_path(get_include_path() . PATH_SEPARATOR . '/')//设置环境变量

/** PHPExcel_IOFactory */

include 'PHPExcel/IOFactory.php'

//$inputFileType = 'Excel5' //这个是读 xls的

$inputFileType = 'Excel2007'//这个是计xlsx的

//$inputFileName = './sampleData/example2.xls'

$inputFileName = './sampleData/book.xlsx'

echo 'Loading file ',pathinfo($inputFileName,PATHINFO_BASENAME),' using IOFactory with a defined reader type of ',$inputFileType,'<br />'

$objReader = PHPExcel_IOFactory::createReader($inputFileType)

$objPHPExcel = $objReader->load($inputFileName)

/*

$sheet = $objPHPExcel->getSheet(0)

$highestRow = $sheet->getHighestRow()//取得总行数

$highestColumn = $sheet->getHighestColumn()//取得总列

*/

$objWorksheet = $objPHPExcel->getActiveSheet()//取得总行数

$highestRow = $objWorksheet->getHighestRow()//取得总列数

echo 'highestRow='.$highestRow

echo "<br>"

$highestColumn = $objWorksheet->getHighestColumn()

$highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn)//总列数

echo 'highestColumnIndex='.$highestColumnIndex

echo "<br />"

$headtitle=array()

for ($row = 1$row <= $highestRow$row++)

{

$strs=array()

//注意highestColumnIndex的列数索引从0开始

for ($col = 0$col <$highestColumnIndex$col++)

{

$strs[$col] =$objWorksheet->getCellByColumnAndRow($col, $row)->getValue()

}

$info = array(

'word1'=>"$strs[0]",

'word2'=>"$strs[1]",

'word3'=>"$strs[2]",

'word4'=>"$strs[3]",

)

//在这儿,你可以连接,你的数据库,写入数据库了

print_r($info)

echo '<br />'

}

?>


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9697598.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-01
下一篇2023-05-01

发表评论

登录后才能评论

评论列表(0条)

    保存