PHP利用phpexcel导入Excel表到Mysql数据库

最近在搞PHP项目,后台很多课题信息需要导入数据库,考虑过一条条导入,但是这样太费时费力。 所以找了下phpexcel的资料,打算利用这个工具把excel表导入数据库,但是发现很多教程都太久远,拿来主义用不了,所以就自己着手搞了一下,对有数据导入需求的可能有帮助。 废话不多,直接上核心代码:

<?php 
 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
 $filename="1.xls";//指定excel文件从上传中取出
 $objPHPExcel = $objReader->load($filename); //$filename可以是上传的文件,或者是指定的文件
 $sheet = $objPHPExcel->getSheet(0);
 $highestRow = $sheet->getHighestRow(); // 取得总行数
 $highestColumn = $sheet->getHighestColumn(); // 取得总列数
 $k = 0;
 //循环读取excel文件,读取一条,插入一条
 //j表示从哪一行开始读取
 //$a表示列号
 $conn = mysqli_connect($servername, $username, $password, $dbname); //连接数据库,自己修改即可
 mysqli_set_charset($coon, "utf8"); //设置字符utf-8
 for($j=2;$j&lt;=$highestRow;$j++) //j=2是因为第一行表为提示,从第二行开始取 { 
 $a = $objPHPExcel->getActiveSheet()->getCell("A".$j)->getValue();//获取A列的值
 $b = $objPHPExcel->getActiveSheet()->getCell("B".$j)->getValue();//获取B列的值
 $c = $objPHPExcel->getActiveSheet()->getCell("C".$j)->getValue();//获取C列的值
 $sql = "INSERT INTO kt (ktname,ktform,ktteacher)
 VALUES ('$a','$b','$c')"; //插入数据库
 $result = mysqli_query($conn, $sql);
 if($result){
 $sta="ok";
 }
 else{
 $sta="on";
 }
 }
 if($sta=="ok"){
 echo '<script>alert("数据导入成功!");window.location.href="xk_change.php";</script>';
 }}
 $filename = $pwd;
 fopen($filename,'a+');
 unlink($filename);
 ?>

核心代码就上面这点,最重要的就是导入phpexcel库,然后轮询导入的数据,再存入数据库。 我把所有文件打了个包,放在了coding,不懂的小伙伴下载改改就能用了: https://coding.net/u/cvc/p/phpexcel 全部代码里面包含了上传-存盘-写入数据库-删除上传的文件,有需要的自行修改即可。

» 本文链接:PHP利用phpexcel导入Excel表到Mysql数据库 » 转载请注明来源:刺客博客

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏芋道源码1024

数据库中间件 Sharding-JDBC 源码分析 —— 事务(一)之BED

本文主要基于 Sharding-JDBC 1.5.0 正式版 1. 概述 2. 最大努力送达型 3. 柔性事务管理器 3.3.1 创建柔性事务 3.1 概念 3...

4915
来自专栏IT笔记

Solr如何使用游标进行深度分页查询

通常,我们的应用系统,如果要做一次全量数据的读取,大多数时候,采用的方式会是使用分页读取的方式,然而 分页读取的方式,在大数据量的情况下,在solr里面表现并...

4147
来自专栏咸鱼不闲

solr中使用IKAnalyzer配置同义词,停止词,扩展词

第一步 将IKAnalyzer2012FF_u1放到solr-4.7.2/example/solr-webapp/webapp/WEB-INF/lib 目录下 ...

994
来自专栏程序员与猫

Elasticsearch 的一些关键概念

我更喜欢把 Elasticsearch 作为一种 nosql 去理解,它的一些开发概念和 MongoDB 以及 Redis 没有太大的区别,不过了解 Elast...

19210
来自专栏JackeyGao的博客

Django + MySQL 查询不区分大小写问题

由于测试环境的 sqlite 没有问题, 所以怀疑在 mysql 的配置上面。 原来是字符集校对规则的问题, utf8_general_ci 不区分大小写, 可...

982
来自专栏java学习

Hibernate学习笔记2

定义hbm.xml映射文件和pojo类时都需要定义主键,Hibernate中定义的主键类型包括:自然主键和代理主键:

934
来自专栏我是攻城师

Solr中如何使用游标进行深度分页查询

3446
来自专栏性能与架构

分库后如何处理分页?

在数据量过大以后,通常都会进行分库操作,把一张表拆分到不同数据库中 例如 tb1 表被拆分到3个库中,分库1、分库2、分库3 现在想执行分页操作 SELECT ...

3068
来自专栏漏斗社区

工具| 诸神之眼nmap定制化之NSE进阶

上一期斗哥跟大家介绍了Nmap中NSE脚本和常见的NSE的API,本期将为大家介绍Nmap的库文件以及如何利用Nmap的自身库将nmap的扫描结果保存在数据中。...

3387
来自专栏IT 指南者专栏

【SSH框架】之Hibernate系列(一)

微信公众号:compassblog 欢迎关注、转发,互相学习,共同进步! 有任何问题,请后台留言联系! 1、Hibernate框架概述 (1)、什么是Hiber...

2698

扫码关注云+社区