加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

PHP行使PHPExcel实现批量上传到数据库的要领

发布时间:2021-01-19 04:11:33 所属栏目:编程 来源:网络整理
导读:此例子只行使execel2003的.xls文档,若行使的是其他版本,可以生涯名目为“Execel 97-2003 事变簿(*.xls)”即.xls文件范例即可! 成果声名:只能上传Excel2003范例的xls文件,巨细不高出5M。可下载例子模板添加数据后即可上传! 前台test.php页面 上传表格 运

此例子只行使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暗示自动添加
$sql = "INSERT INTO house VALUES(null,'$a','$b','$c','$d')";
// echo "$sql";
// exit();
$res = mysql_query($sql);
if ($res) {
  echo "<script>alert('添加乐成!');window.location.href='./test.php';</script>";

}else{
  echo "<script>alert('添加失败!');window.location.href='./test.php';</script>";
  exit();
}

}
}
}

//挪用
upExecel();
?>

结果为:

若未选摘要上传的文件,会提醒“未选择表格”;若表格文件高出5M,提醒;若上传的文件范例不是xls,会提醒!

以上这篇PHP行使PHPExcel实现批量上传到数据库的要领就是小编分享给各人的所有内容了,但愿能给各人一个参考,也但愿各人多多支持编程之家。

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读