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


Posted in PHP onJune 08, 2017

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

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

前台test.php页面

<!DOCTYPE html>
<html>
<head>
  <title></title>
</head>
<meta charset="utf-8">
<body>
<form enctype="multipart/form-data" action="./Process.php" method="post">
  <table>
    <tr><td align="center" colspan="2"><font style="font-size: 40px; font-family: 华文彩云;" >上传表格</font></td></tr>
    <tr><td>请先<a href="./sample/sample01.xls" rel="external nofollow" >下载excel例子模板</a>编辑后上传文件</td></tr>
 <tr>
    <td>请选择你要上传的文件</td>
    <td><input type="file" name="myfile"></td>
    </tr>
    <tr><td><input type="submit" value="上传文件" /></td></tr>
  </table>
</form>
</body>
</html>

运行结果:

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

后台Process.php页面

<?php
header("Content-type:text/html;charset=utf-8");

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

function upExecel(){

//判断是否选择了要上传的表格
if (empty($_POST['myfile'])) {
  echo "<script>alert(您未选择表格);history.go(-1);</script>";
}

//获取表格的大小,限制上传表格的大小5M
$file_size = $_FILES['myfile']['size'];
if ($file_size>5*1024*1024) {
echo "<script>alert('上传失败,上传的表格不能超过5M的大小');history.go(-1);</script>";
  exit();
}

//限制上传表格类型
$file_type = $_FILES['myfile']['type'];
//application/vnd.ms-excel 为xls文件类型
if ($file_type!='application/vnd.ms-excel') {
  echo "<script>alert('上传失败,只能上传excel2003的xls格式!');history.go(-1)</script>";
 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实现批量上传到数据库的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
用PHP4访问Oracle815
Oct 09 PHP
用PHP进行MySQL删除记录操作代码
Jun 07 PHP
PHP 多维数组排序实现代码
Aug 05 PHP
php学习笔记 面向对象的构造与析构方法
Jun 13 PHP
php数组函数序列之in_array() - 查找数组中是否存在指定值
Nov 07 PHP
PHP设计模式之装饰者模式
Feb 29 PHP
php 使用file_get_contents读取大文件的方法
Nov 13 PHP
Yii扩展组件编写方法实例分析
Jun 29 PHP
PHP编程中的Session阻塞问题与解决方法分析
Aug 07 PHP
PHP实现负载均衡下的session共用功能
Apr 17 PHP
PHP SESSION机制的理解与实例
Mar 22 PHP
php函数式编程简单示例
Aug 08 PHP
iis6手工创建网站后无法运行php脚本的解决方法
Jun 08 #PHP
PHP简单获取随机数的常用方法小结
Jun 07 #PHP
laravel 5.1下php artisan migrate的使用注意事项总结
Jun 07 #PHP
PHP获取redis里不存在的6位随机数应用示例【设置24小时过时】
Jun 07 #PHP
解决laravel 5.1报错:No supported encrypter found的办法
Jun 07 #PHP
PHP框架Laravel中实现supervisor执行异步进程的方法
Jun 07 #PHP
php利用ffmpeg提取视频中音频与视频画面的方法详解
Jun 07 #PHP
You might like
BBS(php &amp; mysql)完整版(六)
2006/10/09 PHP
用Php编写注册后Email激活验证的实例代码
2013/03/11 PHP
php的数组与字符串的转换函数整理汇总
2013/07/18 PHP
PHP爬虫之百万级别知乎用户数据爬取与分析
2016/01/22 PHP
JQuery 常用方法基础教程
2009/02/06 Javascript
js arguments.callee的应用代码
2009/05/07 Javascript
jquery.qrcode在线生成二维码使用示例
2013/08/21 Javascript
node.js中的fs.link方法使用说明
2014/12/15 Javascript
JS定义类的六种方式详解
2016/05/12 Javascript
Vue.js组件使用开发实例教程
2016/11/01 Javascript
Bootstrap列表组学习使用
2017/02/09 Javascript
vue.js选中动态绑定的radio的指定项
2017/06/02 Javascript
SpringMVC简单整合Angular2的示例
2017/07/31 Javascript
Webpack设置环境变量的一些误区详解
2019/12/19 Javascript
JS脚本实现定时到网站上签到/签退功能
2020/04/22 Javascript
JavaScript cookie原理及使用实例
2020/05/08 Javascript
Python标准库之sqlite3使用实例
2014/11/25 Python
Python面向对象之类的内置attr属性示例
2018/12/14 Python
python的pytest框架之命令行参数详解(下)
2019/06/27 Python
用Python抢火车票的简单小程序实现解析
2019/08/14 Python
python读写Excel表格的实例代码(简单实用)
2019/12/19 Python
matlab中imadjust函数的作用及应用举例
2020/02/27 Python
Python 在局部变量域中执行代码
2020/08/07 Python
如何用用Python将地址标记在地图上
2021/02/07 Python
意大利香水和彩妆护肤品购物网站:Ditano
2017/08/13 全球购物
澳大利亚领先的在线机械五金、园艺和存储专家:Edisons
2018/03/24 全球购物
Fossil美国官网:化石手表、手袋、首饰及配饰
2019/02/17 全球购物
德国家具、照明、家居用品网上商店:Wayfair.de
2020/02/13 全球购物
explicit和implicit的含义
2012/11/15 面试题
战友聚会邀请函
2014/01/18 职场文书
原材料检验岗位职责
2014/03/15 职场文书
廉洁家庭事迹材料
2014/05/15 职场文书
投标文件签署授权委托书范本
2014/10/12 职场文书
群众路线个人整改措施
2014/10/24 职场文书
小学优秀教师先进事迹材料
2014/12/16 职场文书
SQL Server内存机制浅探
2022/04/06 SQL Server