文档章节

tp实现excel的导入和导出

卫刚刚
 卫刚刚
发布于 2017/09/02 15:39
字数 1108
阅读 66
收藏 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里面的数据也以你真是的表为基础

© 著作权归作者所有

卫刚刚
粉丝 2
博文 33
码字总数 13728
作品 0
私信 提问
加载中

评论(0)

thinkphp3.2和phpexcel导出带生成图片完美案例

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

IT阿飞
2017/08/25
0
0
PHPExcel-1.8.1导入、导出Excel表格

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

老K8
2017/06/09
0
0
完整的thinphp+phpexcel实现excel报表的输出(有图有效果)

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

mickelfeng
2013/05/08
369
0
全网最全最简单使用easypoi导入导出Excel的操作手册

文章目录 概况 easypoi 简介 特性 常用注解 EasyPOI的使用 1.引入依赖 注解方式导出Excel 注解方式导入Excel Excel导入校验 定制化修改 总结 参考代码 参考 概况 今天做Excel导出时,发现了一...

码农飞哥
2019/01/29
0
0
Object-Excel映射的通用解决方案--FastEJ

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

悟达
2016/09/14
804
0

没有更多内容

加载失败,请刷新页面

加载更多

MySQL Not exists - 一个你不需要会的语法

not exists - 就是字面意思: 不存在. A表里某个字段的值不在B表里; 返回符合条件的A表记录. 如: select a.id, a.codefrom table_a a where not exists ( select b.code from table_...

园领T
26分钟前
11
0
零基础Python学习路线及每个阶段学习目标

零基础Python学习路线及阶段学习目标,首先应该夯实Python核心基础、Web前端编程、Django开发框架、Flask开发框架、爬虫与数据分析等知识,理解机器学习相关的基本概念及系统处理流程。 零基...

每天学Python
28分钟前
12
0
编译flink 源码

首先clone源码 git clone git://github.com/apache/flink.git 然后切换到blink分支 git checkout blink 编辑 flink-filesystems 下的pom文件,注释掉 mapr,如下 <modules><module......

jingshishengxu
33分钟前
28
0
springBoot之配置文件的读取以及过滤器和拦截器的使用

springBoot之配置文件的读取以及过滤器和拦截器的使用 前言 在之前的学习springBoot中,成功的实现了Restful风格的基本服务。但是想将之前的工程作为一个项目来说,那些是仅仅不够的。可能还...

鹏十二
48分钟前
33
0
Springboot在Idea Intellij汉字Unicode读取乱码问题

问题核心:Unicode编码中的字母需要小写。比如\u8bbe\u5907\u53f7 首先,了解清楚Unicode编码是什么东西。请读者自己搜索。 然后,我们要清楚springboot是怎么加载配置文件的。兴趣的读者可以...

sunranhou
53分钟前
19
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部