PHP使用PHPExcel实现批量上传到数据库的方法

开发技术 作者: 2024-08-17 17:00:01
下面小编就为大家带来一篇PHP使用PHPExcel实现批量上传到数据库的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

此例子只使用execel2003的.xls文档,若使用的是其他版本,可以保存格式为“Execel 97-2003 工作簿(*.xls)”即.xls文件类型即可!

功能说明:只能上传Excel2003类型的xls文件,大小不超过5M。可下载例子模板添加数据后即可上传!

前台test.PHP页面

运行结果:

后台Process.PHP页面

//链接数据库
$link = @MysqL_connect('localhost','root','') or die('连接数据库失败');
MysqL_select_db('test',$link);
MysqL_query('set names utf8');

function upExecel(){

//判断是否选择了要上传的表格
if (empty($_POST['myfile'])) {
echo "";
}

//获取表格的大小,限制上传表格的大小5M
$file_size = $_FILES['myfile']['size'];
if ($file_size>510241024) {
echo "";
exit();
}

//限制上传表格类型
$file_type = $_FILES['myfile']['type'];
//application/vnd.ms-excel 为xls文件类型
if ($file_type!='application/vnd.ms-excel') {
echo "";
exit();
}

//判断表格是否上传成功
if (is_uploaded_file($_FILES['myfile']['tmp_name'])) {
require_once 'PHPExcel.PHP';
require_once 'PHPExcel/IOFactory.PHP';
require_once 'PHPExcel/Reader/Excel5.PHP';
//以上三步加载PHPExcel的类

$objReader = PHPExcel_IOFactory::createReader('Excel5');//use excel2007 for 2007 format
//接收存在缓存中的excel表格
$filename = $_FILES['myfile']['tmp_name'];
$objPHPExcel = $objReader->load($filename); //$filename可以是上传的表格,或者是指定的表格
$sheet = $objPHPExcel->getSheet(0);
$highestRow = $sheet->getHighestRow(); // 取得总行数
// $highestColumn = $sheet->getHighestColumn(); // 取得总列数

//循环读取excel表格,读取一条,插入一条
//j表示从哪一行开始读取 从第二行开始读取,因为第一行是标题不保存
//$a表示列号
for($j=2;$j<=$highestRow;$j++)
{
$a = $objPHPExcel->getActiveSheet()->getCell("A".$j)->getValue();//获取A(业主名字)列的值
$b = $objPHPExcel->getActiveSheet()->getCell("B".$j)->getValue();//获取B(密码)列的值
$c = $objPHPExcel->getActiveSheet()->getCell("C".$j)->getValue();//获取C(手机号)列的值
$d = $objPHPExcel->getActiveSheet()->getCell("D".$j)->getValue();//获取D(地址)列的值

//null 为主键id,自增可用null表示<a href="https://www.jb51.cc/tag/zidongtianjia/" target="_blank" class="keywords">自动添加</a>
$<a href="https://www.jb51.cc/tag/sql/" target="_blank" class="keywords">sql</a> = "INSERT INTO house VALUES(null,'$a','$b','$c','$d')";
// echo "$<a href="https://www.jb51.cc/tag/sql/" target="_blank" class="keywords">sql</a>";
// exit();
$res = <a href="https://www.jb51.cc/tag/MysqL/" target="_blank" class="keywords">MysqL</a>_query($<a href="https://www.jb51.cc/tag/sql/" target="_blank" class="keywords">sql</a>);
if ($res) {
  echo "<script>alert('<a href="https://www.jb51.cc/tag/tianjia/" target="_blank" class="keywords">添加</a>成功!');window.location.href='./test.<a href="https://www.jb51.cc/tag/PHP/" target="_blank" class="keywords">PHP</a>';</script>";

}else{
  echo "<script>alert('<a href="https://www.jb51.cc/tag/tianjia/" target="_blank" class="keywords">添加</a>失败!');window.location.href='./test.<a href="https://www.jb51.cc/tag/PHP/" target="_blank" class="keywords">PHP</a>';</script>";
  exit();
}

}
}
}

//调用
upExecel();
?>

效果为:

若未选择要上传的文件,会提示“未选择表格”;若表格文件超过5M,提示;若上传的文件类型不是xls,会提示!

以上这篇PHP使用PHPExcel实现批量上传到数据库的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

原创声明
本站部分文章基于互联网的整理,我们会把真正“有用/优质”的文章整理提供给各位开发者。本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
本文链接:http://www.jiecseo.com/news/show_63894.html