文档章节

tp实现excel的导入和导出

卫刚刚
 卫刚刚
发布于 2017/09/02 15:39
字数 1108
阅读 32
收藏 0

一:下载phpExcel第三方类库

              下载地址:http://www.thinkphp.cn/topic/14005.html下载官方网站;

二:下载成功之后将文件放到Vendor下:ThinkPHP\Extend\Vendor\PHPExcel\PHPExcel.php。

三:配置数据库的信息操作(我的是在home文件夹下(application/home/config/config.php)添加如下配置):

<?php
return array(
    //'配置项'=>'配置值'
    'DB_TYPE'   => 'mysql', // 数据库类型
    'DB_HOST'   => 'localhost', // 服务器地址
    'DB_NAME'   => 'db_oa', // 数据库名
    'DB_USER'   => 'root', // 用户名
    'DB_PWD'    => 'root', // 密码
    'DB_PORT'   => 3306, // 端口
     'DB_PREFIX' => 'tg_', // 数据库表前缀
//    'DB_FIELDS_CACHE'       =>  false,        // 启用字段缓存(开发时这个要写成false)
)
?>       

四:模板代码:        

<html>
<head>

</head>
<body>
<P><a href="{:U('Index/expUser')}" >导出数据并生成excel</a></P><br/>
<form action="{:U('Index/impUser')}" method="post" enctype="multipart/form-data">
    <input type="file" name="import"/>
    <input type="hidden" name="table" value="tablename"/>
    <input type="submit" value="导入"/>
</form>
</body>
</html>
<?php

?>

实现功能的控制器方法:

  1>导出数据方法的实现:

function expUser(){//导出Excel
        //获取表头名:
        $xlsName  = "evaluate_check";
        //获取文件里面具体的数据
        $xlsCell  = array('教师检查作业表', '所属功能','所属权限','所属学生','学生答案'
        );
//        连接数据库找到查询的表
        $xlsModel = M('evaluate_check');
//        通过调用select方法field查找数据表里面的字段
        $xlsData  = $xlsModel->Field('id,tep_id,tet_id,student_id,student_anwser')->select();
        $this->exportExcel($xlsName,$xlsCell,$xlsData);
    }
    public function exportExcel($expTitle,$expCellName,$expTableData){
//        抓取文件名将字符编码转换成utf8格式
        $xlsTitle = iconv('utf-8', 'gb2312', $expTitle);//文件名称
//       命名Excel文件的文件名称,通过时间函数随即打乱
        $fileName = $_SESSION['account'].date('_YmdHis');//or $xlsTitle 文件名称可根据自己情况设定
        //通过count函数获取到字段的行数
        $cellNum = count($expCellName);
       //获取具体的值
        $dataNum = count($expTableData);
//        var_dump(count($expTableData));exit;
        //引入具体的类库
        vendor("PHPExcel.PHPExcel");
//        echo '111111dfgfhj';exit;
        //实例化方法,得到所有的方法;
        $objPHPExcel = new \PHPExcel();
        //设置单元格的行数
        $cellName = array('A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z','AA','AB','AC','AD','AE','AF','AG','AH','AI','AJ','AK','AL','AM','AN','AO','AP','AQ','AR','AS','AT','AU','AV','AW','AX','AY','AZ');

//        var_dump($cellName);exit;
//        var_dump($objPHPExcel->getActiveSheet(0)->mergeCells('A1:'.$cellName[$cellNum-1].'1'));exit;
        $objPHPExcel->getActiveSheet(0)->mergeCells('A1:'.$cellName[$cellNum-1].'1');//合并单元格
//        echo '1111111';exit;
//        var_dump($objPHPExcel->getActiveSheet(0)->mergeCells('A1:'.$cellName[$cellNum-1].'1'));exit;
//         $objPHPExcel->setActiveSheetIndex(0)->setCellValue('A1', $expTitle.'  Export time:'.date('Y-m-d H:i:s'));
        //对获取的行号进行循环遍历并且赋值
        for($i=0;$i<$cellNum;$i++){
           $objPHPExcel->setActiveSheetIndex(0)->setCellValue($cellName[$i].'2', $expCellName[$i]);
        }
        $objPHPExcel->getActiveSheet()->setTitle($expTitle);
        $objPHPExcel->setActiveSheetIndex(0)->setCellValue('A1',$expTitle);
        // Miscellaneous glyphs, UTF-8
//        var_dump($dataNum);exit;
        //对获取的列好进行遍历赋值输出
        for($i=0;$i<$dataNum;$i++){
            for($j=0;$j<$cellNum;$j++){
               $a  = array_values($expTableData[$i]) ;
                $objPHPExcel->getActiveSheet(0)->setCellValue($cellName[$j].($i+3),$a[$j]);
            }
        }
        ob_end_clean();//清楚缓冲避免乱码
        header('pragma:public');
        //设置表头信息
        header('Content-type:application/vnd.ms-excel;charset=utf-8;name="'.$xlsTitle.'.xls"');
        header("Content-Disposition:attachment;filename=$fileName.xls");//attachment新窗口打印inline本窗口打印
        //通过调用如下方法来创建Excel将值写入
        $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
        //进行保存下载
        $objWriter->save('php://output');
        exit;
    }

3>导入数据方法的实现:

      (1)选取你要导入的xls文件,进行操作 

      (2)代码如下: 

function impUser(){
         //判断你的文件是否为空
        if (!empty($_FILES)) {
//            引入类库
            vendor("PHPExcel.PHPExcel");
            //获取存储文件的文件名
            $file_name=$_FILES['import']['tmp_name'];
            //调用如下方法来读取你表里面的信息
            $objReader = \PHPExcel_IOFactory::createReader('Excel5');
//            var_dump($objReader);exit;
            //读取到的临时文件名的信息
            $objPHPExcel = $objReader->load($file_name,$encode='utf-8');
            //获取Excel表格的列数
            $sheet = $objPHPExcel->getSheet(0);
            $highestRow = $sheet->getHighestRow(); // 取得总行数

            $highestColumn = $sheet->getHighestColumn(); // 取得总列数
//            将值进行写入
            for($i=3;$i<=$highestRow;$i++)
            {
                $data['account']= $data['truename'] = $objPHPExcel->getActiveSheet()->getCell("B".$i)->getValue();
                $sex = $objPHPExcel->getActiveSheet()->getCell("C".$i)->getValue();
                // $data['res_id']    = $objPHPExcel->getActiveSheet()->getCell("D".$i)->getValue();
                $data['class'] = $objPHPExcel->getActiveSheet()->getCell("E".$i)->getValue();
                $data['year'] = $objPHPExcel->getActiveSheet()->getCell("F".$i)->getValue();
                $data['city']= $objPHPExcel->getActiveSheet()->getCell("G".$i)->getValue();
                $data['company']= $objPHPExcel->getActiveSheet()->getCell("H".$i)->getValue();
                $data['zhicheng']= $objPHPExcel->getActiveSheet()->getCell("I".$i)->getValue();
                $data['zhiwu']= $objPHPExcel->getActiveSheet()->getCell("J".$i)->getValue();
                $data['jibie']= $objPHPExcel->getActiveSheet()->getCell("K".$i)->getValue();
                $data['honor']= $objPHPExcel->getActiveSheet()->getCell("L".$i)->getValue();
                $data['tel']= $objPHPExcel->getActiveSheet()->getCell("M".$i)->getValue();
                $data['qq']= $objPHPExcel->getActiveSheet()->getCell("N".$i)->getValue();
                $data['email']= $objPHPExcel->getActiveSheet()->getCell("O".$i)->getValue();
                $data['remark']= $objPHPExcel->getActiveSheet()->getCell("P".$i)->getValue();
                $data['sex']=$sex=='男'?1:0;
                $data['res_id'] =1;

                $data['last_login_time']=0;
                $data['create_time']=$data['last_login_ip']=$_SERVER['REMOTE_ADDR'];
                $data['login_count']=0;
                $data['join']=0;
                $data['avatar']='';
                $data['password']=md5('123456');
                //通过以下方法,将值添加到数据库中;
                M('Member')->add($data);

            }
            $this->success('导入成功!');
        }else
        {
            $this->error("请选择上传的文件");
        }

    }

说明:最后的数据库信息以你具体的表信息为主,在M(‘表明’)->add($data);

         $data里面的数据也以你真是的表为基础

© 著作权归作者所有

共有 人打赏支持
卫刚刚
粉丝 1
博文 33
码字总数 13728
作品 0
私信 提问
PHPExcel-1.8.1导入、导出Excel表格

仅留作记录使用: /** * 读取文件方案一 */ public function readExcel() { requireonce VENDORPATH . 'PhpExcel/PHPExcel/IOFactory.php'; // 循环遍历数据 $objReader = PHPExcel_IOFactor......

老K8
2017/06/09
0
0
thinkphp3.2和phpexcel导出带生成图片完美案例

thinkphp3.2和phpexcel导出带生成图片完美案例 新手一枚,接触tp也有一个月了,最近公司要求报表导出要有图片生成,特意花时间研究了下,看事例代码 注意事项: 1.phpexcel下载地址:http://p...

IT阿飞
2017/08/25
0
0
Object-Excel映射的通用解决方案--FastEJ

FastEJ说明 简介 在互联网信息发展的时代,对报表数据的处理需要一个通用化的解决方案。而导入Excel文件到内存、导出内存数据到Excel文件 是一个普遍化的需求。本项目旨在设计一个Object-Ex...

悟达
2016/09/14
479
0
完整的thinphp+phpexcel实现excel报表的输出(有图有效果)

准备工作: 1.下载phpexcel1.7.6类包; 2.解压至TP框架的ThinkPHPVendor目录下,改类包文件夹名为PHPExcel176,目录结构如下图; 编写代码(以一个订单汇总数据为例): 1. 创建数据库及表; 2...

mickelfeng
2013/05/08
0
0
Excel 快捷导出导入工具--exportExcel

exportExcel 让 excel 导出导入更简单,告别繁琐的 excel 导出,实现自定义导出,模板导出,基于注解导出简单方便。 1、 新建excel导出。 Excel excel = new Excel(); //新建excelExcelSheet...

Jeff_Regan
2017/08/15
1K
5

没有更多内容

加载失败,请刷新页面

加载更多

oh-my-zsh 自定义

GitHub 地址 基于 oh-my-zsh 的自定义配置,增加了一些个人常用插件与皮肤。 采用的是 git submodule 来维护,包括 oh-my-zsh,之所以这么搞,主要是手头有多台 linux 需要维护, 每台机器、...

郁也风
今天
5
0
Docker安装踩坑:E_FAIL 0x80004005的解决

参考 菜鸟教程--Windows Docker 安装 http://www.runoob.com/docker/windows-docker-install.html 官方文档-Install Docker Toolbox on Windows https://docs.docker.com/toolbox/toolbox_in......

karma123
今天
5
0
js垃圾回收机制和引起内存泄漏的操作

JS的垃圾回收机制了解吗? Js具有自动垃圾回收机制。垃圾收集器会按照固定的时间间隔周期性的执行。 JS中最常见的垃圾回收方式是标记清除。 工作原理:是当变量进入环境时,将这个变量标记为“...

Jack088
昨天
17
0
大数据教程(10.1)倒排索引建立

前面博主介绍了sql中join功能的大数据实现,本节将继续为小伙伴们分享倒排索引的建立。 一、需求 在很多项目中,我们需要对我们的文档建立索引(如:论坛帖子);我们需要记录某个词在各个文...

em_aaron
昨天
27
0
"errcode": 41001, "errmsg": "access_token missing hint: [w.ILza05728877!]"

Postman获取微信小程序码的时候报错, errcode: 41001, errmsg: access_token missing hint 查看小程序开发api指南,原来access_token是直接当作parameter的(写在url之后),scene参数一定要...

两广总督bogang
昨天
33
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部