PHP通过使用工具类(PHPExcel)从操作数据库和Excel表
关于用PHPExcel从数据库表导出到Excel表
在网上查了好多关于这方面的资料,今天终于把这个问题解决了。
我个人感觉 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就行了,在此我就不做太多解释了。
二: PHPExcel从excel表导入到mysql数据库
在网上查了好多关于这方面的资料,今天终于把这个问题解决了。
我个人感觉 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就行了,在此我就不做太多解释了。
二: PHPExcel从excel表导入到mysql数据库
error_reporting(E_ALL);
require './Common/Extend/Classes/PHPExcel.php';
require './Common/Extend/Classes/PHPExcel/Reader/Excel2007.php';
require './Common/Extend/Classes/PHPExcel/Reader/Excel5.php';
$info = $upload->getUploadFileInfo();
$filepath = "./Upimg/".$info[0][savename];
$PHPExcel = new PHPExcel();
$PHPReader = new PHPExcel_Reader_Excel2007();
$PHPExcel = $PHPReader->load($filepath);
$sheet = $PHPExcel->getActiveSheet();
$allCol=PHPExcel_Cell::columnIndexFromString($sheet->getHighestColumn());
$allRow=$sheet->getHighestRow();
$M=new Model;
for($j=2;$j<=$allRow;$j++){
$a = $PHPExcel->getActiveSheet()->getCell("A".$j)->getValue();//获取A列的值
$b = $PHPExcel->getActiveSheet()->getCell("B".$j)->getValue();//获取B列的值
$c = $PHPExcel->getActiveSheet()->getCell("C".$j)->getValue();//获取C列的值
$d = $PHPExcel->getActiveSheet()->getCell("D".$j)->getValue();//获取D列的值
$e = $PHPExcel->getActiveSheet()->getCell("E".$j)->getValue();//获取E列的值
$f = $PHPExcel->getActiveSheet()->getCell("F".$j)->getValue();//获取F列的值
$g = $PHPExcel->getActiveSheet()->getCell("G".$j)->getValue();//获取G列的值
$h = $PHPExcel->getActiveSheet()->getCell("H".$j)->getValue();//获取X列的值
$i = $PHPExcel->getActiveSheet()->getCell("I".$j)->getValue();//获取I列的值
$jj = $PHPExcel->getActiveSheet()->getCell("J".$j)->getValue();//获取J列的值
$k = $PHPExcel->getActiveSheet()->getCell("K".$j)->getValue();//获取K列的值
$l = $PHPExcel->getActiveSheet()->getCell("L".$j)->getValue();//获取L列的值
$m = $PHPExcel->getActiveSheet()->getCell("M".$j)->getValue();//获取M列的值
$n = $PHPExcel->getActiveSheet()->getCell("N".$j)->getValue();//获取N列的值
$p = $PHPExcel->getActiveSheet()->getCell("P".$j)->getValue();//获取P列的值
$qq = $PHPExcel->getActiveSheet()->getCell("Q".$j)->getValue();//获取Q列的值
$r = $PHPExcel->getActiveSheet()->getCell("R".$j)->getValue();//获取R列的值
$sql="insert into law_constant(true_name,email,sex,birthday,certificate_num,first_date,law_firm_name,law_firm_address,lawer_xueli,professional,school,work_year,occup_language,word_experience,hobbies) values('".$c."','".$p."','".$d."','".$jj."','".$b."','".$e."','".$f."','".$h."','".$i."','".$k."','".$l."','".$m."','".$n."','".$qq."','".$r."');";
$res=$M->query($sql);
}
if($res[0]==''){
$this->success("导入数据库成功!",'__APP__/Lawerinfo/index');
}else{
$this->error("导入数据库失败!","__APP__/Lawerinfo/index");
}
}
}
}