public function studentImportExcel(){

if (!empty ( $_FILES)){

$upload = new \Think\Upload();                      // 实例化上传类

$upload->maxSize   =     10485760 ;                 // 设置附件上传大小

$upload->exts      =     array('xls','xlsx');       // 设置附件上传类型

$upload->rootPath  = './Public/Excel/';             // 设置附件上传根目录

$upload->autoSub   = false;                         // 将自动生成以photo后面加时间的形式文件夹,关闭

// 上传文件

$info   =   $upload->upload();                                   // 上传文件

$exts   = $info['excel']['ext'];                                 // 获取文件后缀

$filename = $upload->rootPath.$info['excel']['savename'];        // 生成文件路径名

if(!$info) {                                                     // 上传错误提示错误信息

$this->error($upload->getError());

}else{                                                           // 上传成功

import("Org.Util.PHPExcel");                                 // 导入PHPExcel类库,因为PHPExcel没有用命名空间,只能inport导入

$PHPExcel = new \PHPExcel();                                 // 创建PHPExcel对象,注意,不能少了\

if ($exts == 'xls') {                                        // 如果excel文件后缀名为.xls,导入这个类

import("Org.Util.PHPExcel.Reader.Excel5");

$PHPReader = new \PHPExcel_Reader_Excel5();

} else

if ($exts == 'xlsx') {

import("Org.Util.PHPExcel.Reader.Excel2007");

$PHPReader = new \PHPExcel_Reader_Excel2007();

}

$PHPExcel = $PHPReader->load($filename);                     // 载入文件

$currentSheet = $PHPExcel->getSheet(0);                      // 获取表中的第一个工作表,如果要获取第二个,把0改为1,依次类推

$allColumn = $currentSheet->getHighestColumn();              // 获取总列数

$allRow = $currentSheet->getHighestRow();                    // 获取总行数

for ($currentRow = 0; $currentRow <= $allRow; $currentRow ++) {// 循环获取表中的数据,$currentRow表示当前行,从哪行开始读取数据,索引值从0开始

for ($currentColumn = 'A'; $currentColumn <= $allColumn; $currentColumn ++) {// 从哪列开始,A表示第一列

$address = $currentColumn . $currentRow;             // 数据坐标

$ExlData[$currentRow][$currentColumn] = $currentSheet->getCell($address)->getValue();// 读取到的数据,保存到数组$arr中

}

}

$Hint = new \Operation\Controller\HintController();          // 生成操作类对象

$data = studentImportExcel_RAW($ExlData);                    // 调用公用方法的读数组并写入数据库操作

$users = M('users');                                         // 生成数据库对象

$result = $users->addAll($data);                             // 批量写入数据库

if ($result) {                                               // 验证

$Hint->mysuccee("导入成功", "2", "Admin/Users/studentManage");// 跳转学生管理页面

} else {

$Hint->myerror("导入失败,原因可能是excel表中有些用户已被注册。或表格格式错误","5");// 提示错误

}

}

}else {

$this->display();

}

}

function  studentImportExcel_RAW($ExlData){   // 将导入表中的数据添加到  数据库数组中去

$Hint = new \Operation\Controller\HintController();     // 生成操作类对象

for($i = 2,$j=0;$i<sizeof($ExlData);$i++,$j++){

$dataList[] = array(

'username'=>$ExlData[$i]['A'],

'pwd'     =>MD5(11),

'realname'=>$ExlData[$i]['B'],

'stunum'  =>$ExlData[$i]['C'],

'email'   =>$ExlData[$i]['D'],

'phone'   =>$ExlData[$i]['E'],

'photo'   =>$Hint->randPhoto(),

'role'    =>'1',

'intro'   =>'这家伙很懒什么都没留下',

'regdate' =>date('Y-m-d H:i:s', time())         // 写入注册时间

);

}

return $dataList;

}

phpexcel导入数据库 基于thinkphp3.2的更多相关文章

  1. ThinkPhp3.2.3 使用phpExcel导入数据

    public function uploadExcel(){ if (!empty($_FILES)){ $upload = new \Think\Upload(); // 实例化上传类 $uploa ...

  2. thinkphp phpexcel导入

    上次做了一个基于tp3.2.3的phpexcel导出,这次是phpexcel导入,准备材料phpexcel(不知道下载地址的查看我上一篇博文),虽说是基于thinkphp3.2.3来的,也只不过是引入 ...

  3. Thinkphp 用PHPExcel 导入Excel

    搞了个简单的Excel导入, 用的是PHPExcel(百科:用来操作Office Excel文档的一个PHP类库, 基于微软的OpenXML标准和PHP语言) 好, 不说了, 开始吧... 首先得有P ...

  4. [Asp.net]常见数据导入Excel,Excel数据导入数据库解决方案,总有一款适合你!

    引言 项目中常用到将数据导入Excel,将Excel中的数据导入数据库的功能,曾经也查找过相关的内容,将曾经用过的方案总结一下. 方案一 NPOI NPOI 是 POI 项目的 .NET 版本.POI ...

  5. (一)熟悉执行流程——基于ThinkPHP3.2的内容管理框架OneThink学习

    ThinkPHP作为国内具有代表性的PHP框架,经过多年的发展,受到越来越多公司与开发者的青睐.我也在忙里偷闲中抽出部分时间,来学习这个优秀的框架.在开始学习这个框架时,最好通过实例来学习,更容易结合 ...

  6. 使用thinkphp框架实现Excel导入数据库

    之前讲过php实现Excel导出数据库的随笔,链接:https://www.cnblogs.com/nuanai/p/6727711.html 之前的项目用到较多的就是Excel导出,现在用到了Exc ...

  7. phpexcel导入数据出现PHPExcel_RichText Object解决办法

    在导入excel的时候会出现异常情况,有的问题出现PHPExcel_RichText object,错误代码如下 PHPExcel_RichText Object ( [_richTextElemen ...

  8. PHPExcel 导入Excel数据 (导出下一篇我们继续讲解)

    一:使用composer下载 phpoffice/phpexcel 或者直接下载安装包 composer require phpoffice/phpexcel 二 1:导入数据 原理:读取文件,获取文 ...

  9. 转:[Asp.net]常见数据导入Excel,Excel数据导入数据库解决方案,总有一款适合你!

    引言 项目中常用到将数据导入Excel,将Excel中的数据导入数据库的功能,曾经也查找过相关的内容,将曾经用过的方案总结一下. 方案一 NPOI NPOI 是 POI 项目的 .NET 版本.POI ...

随机推荐

  1. pathmunge /etc/profile

    pathmunge () { case ":${PATH}:" in *:"$1":*) ;; *) if [ "$2" = "a ...

  2. hdoj 2087 剪花布条

    剪花布条 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  3. 数字集成电路设计-8-一个简单sobel图像边缘检测加速器的设计,实现,仿真与综合

    引言 图像视频处理等多媒体领域是FPGA应用的最主要的方面之一,边缘检测是图像处理和计算机视觉中的基本问题,所以也是最常用的,随着数据量的不断增加以及对实时性的要求,一般软件已经不能满足实际需要,这时 ...

  4. 超强vim配置文件

    简易安装方法: https://github.com/ma6174/vim 打开终端,执行下面的命令就自动安装好了: wget -qO- https://raw.github.com/ma6174/v ...

  5. nginx配置文件的说明

    设置连接超时时间 http { ## # Basic Settings ## sendfile on; tcp_nopush on; tcp_nodelay on; keepalive_timeout ...

  6. QinQ封装及终结详解

    以下内容摘自正在当当网.京东网.卓越网.互动出版网预售,即将正式发售的<华为交换机学习指南>一书(全书近千页).本书是由华为官方授权,国内第一本,也是唯一一本华为交换机权威学习指南,是华为 ...

  7. jquerymobile-可折叠内容(Collapsible content)

    可能我们在开发中遇到过这样的问题,我们只是看到一个题目或者简单的介绍,然后一点击会在下面展开对应的详细的内容.在jqm中实现这个效果很简单.下面给出一段例子代码: <!DOCTYPE html& ...

  8. EasyUI-增删改操作

    最近公司要用easyui,这里自己看了官网几篇文章,遇到些问题,大多数的问题都是敲代码的时候笔误,其他有些地方确实需要注意一下,这里做些笔记. 1.在mysql中建好表之后修改id字段为递增字段,发现 ...

  9. SystemTimeToFileTime、FileTimeToLocalFileTime、LocalFileTimeToFileTime三函数的跨平台实现

    // test.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <stdlib.h>   #include & ...

  10. Delphi通过ICMP检测与远程主机连接

    { ping IP 地址(返回false or true) 2015-03-23} function PingHost(HostIP: String): Boolean; type PIPOption ...