Thinkphp使用phpexcel导入文件并写入数据库
现实中,我们往往很多地方都需要这样批量导入数据,除了phpexcel还有csv等方法可以解决
下面详细介绍一下使用方法
首先在官方下载安装包解压到本地,然后复制保存到tp框架下的vendor目录下

html页面如下

下面是后端代码:
public function column(){
$grade=D('school')->where(array('parent_id'=>1))->select();
$school = D('schooll')->select();
$this->assign('school',$school);
$this->assign('grade',$grade);
if(IS_POST){
$data_p = I('post.');
if ($data_P['sno']==' ') {
$this->ajaxReturn(array('nr' => '学号已存在!', 'sf' => 0));
}elseif($data_P['sname']==' '){
$this->ajaxReturn(array('nr' => '姓名不为空!', 'sf' => 0));
}elseif($data_P['grade']==' '){
$this->ajaxReturn(array('nr'=> '不为空','sf'=>'0'));
}elseif($data_P['major']==' '){
$this->ajaxReturn(array('nr'=>'不为空','sf'=>'0'));
}elseif($data_P['classs']==' '){
$this->ajaxReturn(array('nr'=>'不为空','sf'=>'0'));
}elseif($data_P['school']==' '){
$this->ajaxReturn(array('nr'=>'不为空','sf'=>'0'));
}else{
$student = M('student')->add(array('sno'=>$data_p['sno'],'passwd'=>md5($data_p['passwd']),'sname'=>$data_p['sname'],'zt'=>$data_p['checkresult'],'majorname'=>$data_p['major'],'classname'=>$data_p['classs'],'gradename'=>$data_p['school'],'schoolname'=>$data_p['grade']));
}
if ($student) {
$this->ajaxReturn(array('nr' => '添加成功'.$data_P['major'], 'sf' => 0));
} else {
$this->ajaxReturn(array('nr' => '添加失敗!', 'sf' => 0));
}
}
$this->display('index/column');
}
public function upload() {
if (!empty($_FILES)) {
$config = array(
'exts' => array('xlsx','xls'),
'maxSize' => 3145728,
'rootPath' =>"./Excel/",
'subName' => array('date','Ymd'),
);
$upload = new \Think\Upload($config);
if (!$info = $upload->upload()){
$this->error($upload->getError());
}else{
//vendor('PHPExcel.PHPExcel');/////引入类库
//vendor('PHPExcel.Reader.Excel5');
import("vendor.PHPExcel");
import("vendor.PHPExcel.Reader.Excel5");
$objPHPExcel = new \PHPExcel();/////初始化引入的方法
$PHPReader=new \PHPExcel_Reader_Excel5();
$file_name=$upload->rootPath.$info['excel']['savepath'].$info['excel']['savename'];
}
$objReader = $PHPReader->load($file_name);
$extension = strtolower(pathinfo($file_name, PATHINFO_EXTENSION));
//判断导入表格后缀格式
if ($extension == 'xlsx') {
$objReader =\PHPExcel_IOFactory::createReader('Excel2007');
$objPHPExcel =$objReader->load($file_name, $encode = 'utf-8');
} elseif($extension == 'xls'){
$objReader =\PHPExcel_IOFactory::createReader('Excel5');
$objPHPExcel =$objReader->load($file_name, $encode = 'utf-8');
}
$sheet =$objPHPExcel->getSheet(0);//获取表中第一个工作表
$highestRow = $sheet->getHighestRow();//取得总行数
$highestColumn =$sheet->getHighestColumn(); //取得总列数
for($currentRow=1;$currentRow<=$highestRow;$currentRow++){
for($currentColumn='A';$currentColumn<=$highestColumn;$currentColumn++){
$address=$currentColumn.$currentRow;
$arr[$currentRow][$currentColumn]=$sheet->getCell($address)->getValue();
}
for ($i = 2; $i <= $highestRow; $i++) {
$data_p['sno'] =$objPHPExcel->getActiveSheet()->getCell("A" . $i)->getValue();
$passwd =$objPHPExcel->getActiveSheet()->getCell("B" .$i)->getValue();
$data_p['passwd']=md5($passwd);
$data_p['sname'] =$objPHPExcel->getActiveSheet()->getCell("C" .$i)->getValue();
$data_p['zt'] = '0';
$data_p['majorname'] = $objPHPExcel->getActiveSheet()->getCell("D". $i)->getValue();
$data_p['classname'] =$objPHPExcel->getActiveSheet()->getCell("E" .$i)->getValue();
$data_p['gradename'] =$objPHPExcel->getActiveSheet()->getCell("F" . $i)->getValue();
$data_p['schoolname'] =$objPHPExcel->getActiveSheet()->getCell("G" . $i)->getValue();
$ex=M('Student')->add($data_p);
}
if($ex){
$this->success('导入成功!');
}else{
$this->error("请选择上传的文件");
}
}
}





好的具体的就是这些。哪里不懂可以留言1119702968@qq.com咨询。
Thinkphp使用phpexcel导入文件并写入数据库的更多相关文章
- Thinkphp 用PHPExcel 导入Excel
搞了个简单的Excel导入, 用的是PHPExcel(百科:用来操作Office Excel文档的一个PHP类库, 基于微软的OpenXML标准和PHP语言) 好, 不说了, 开始吧... 首先得有P ...
- (OAF)jdeveloper集成log4j并将日志输出到指定文件并写入数据库
参考: How to configure Log4j in JDev 11g Ever wanted to use log4j in your adf project ? Well though Or ...
- nio实现文件读取写入数据库或文件
1.nio实现读取大文件,之后分批读取写入数据库 2.nio实现读取大文件,之后分批写入指定文件 package com.ally; import java.io.File; import java. ...
- PHPExcel使用-使用PHPExcel导入文件
导入步骤: 1. 实例化excel读取对象 2. 加载excel文件 ----------------> ( 1>. 全部加载. 2>. 选择加载. ) 3. 读取excel文件 - ...
- Oracle数据泵远程导入文件到本地数据库
--以dba身份登录 C:\Users\Administrator>sqlplus / as sysdba --创建用户 SQL> create user bfzg0828 identif ...
- 使用phpExcel导入Excel进入Mysql数据库
1.http://phpexcel.codeplex.com/下载phpExcel 2. <? require_once 'PHPExcel.php'; require_once 'PHPExc ...
- ThinkPhp 使用PhpExcel导出导入多语言文件
在ThinkPHP 里已经实现了多语言功能,只要在指定的目录下创建对应的语言文件并填充内容,即可实现多语言功能 而多语言的翻译却是一个很麻烦的事情,因为客户特定的行业问题导致我们翻译可能是不准确的 于 ...
- 十万级百万级数据量的Excel文件导入并写入数据库
一.需求分析 最近接到一个需求,导入十万级,甚至可能百万数据量的记录了车辆黑名单的Excel文件,借此机会分析下编码过程; 首先将这个需求拆解,发现有三个比较复杂的问题: 问题一:Excel文件导入后 ...
- ThinkPHP使用PHPExcel实现Excel数据导入导出完整实例
这篇文章主要介绍了ThinkPHP使用PHPExcel实现Excel数据导入导出,非常实用的功能,需要的朋友可以参考下 本文所述实例是使用在Thinkphp的开发框架上,要是使用在其他框架也是同样的方 ...
随机推荐
- (转)[疯狂Java]NIO:Channel的map映射
原文出自:http://blog.csdn.net/lirx_tech/article/details/51396268 1. 通道映射技术: 1) 其实就是一种快速读写技术,它将通道所连接的数据节点 ...
- Java基础总结--IO总结2
1.键盘录入--Java具有特定的对象封装这些输入输出设备在System类定义 in-InputStream类型和out-PrintStream类型成员变量阻塞是方法:read()无数据就阻塞wind ...
- 安利一波那个叫做 hutool 的通用工具类库
摘自3.1.1版本作者发布原话,当时看到有点说不上的情绪,为作者的坚持.热爱点个赞. 已经想不起来是怎样结识 Hutool 的,但 Hutool 伴随几个项目的推进,获得了同事一致好评. 没经过实践和 ...
- 对Java原子类AtomicInteger实现原理的一点总结
java原子类不多,包路径位于:java.util.concurrent.atomic,大致有如下的类: java.util.concurrent.atomic.AtomicBoolean java. ...
- angular-utils-ui-breadcrumbs使用心得
angular-utils-ui-breadcrumbs是一个用来自动生成面包屑导航栏的一个插件,需要依赖angular.UIRouter和bootstrap3.css.生成的界面截图如下,点击相应的 ...
- 值得学习的C/C++开源框架(转)
值得学习的C语言开源项目 - 1. Webbench Webbench是一个在linux下使用的非常简单的网站压测工具.它使用fork()模拟多个客户端同时访问我们设定的URL,测试网站在压力下工作的 ...
- MQTT——订阅报文
我们已经把相关的连接报文搞定了.笔者想来想去还是决定先讲解一下订阅报文(SUBSCRIBE ).如果传统的通信方式是客户端和服务端之间一般就直接传输信息.但是MQTT的通信方式是通过发布/订阅的方式进 ...
- 自建梯子教程:vultr+ssr+SwitchyOmega
1 综述 在饱受蓝灯挂掉之苦半个月后,终于决定自己搭建VPS服务器FQ了.虽然网上VPS服务器教程很多,但是我按照那些教程弄好VPS服务器总是不稳定,用着用着就不能用了.这应该是这次GFW升级带来的后 ...
- Mysql 删除重复记录,只保留最小的一条
delete from `jb_postcontent` where id not in(select min(id) from (select * from `jb_postcontent`) as ...
- Hibernate开发文档
hibernate配置 映射约束文件 <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3. ...