thinkphp5 使用PHPExcel 导入导出

首先下载PHPExcel类。网上很多,自行下载。

然后把文件放到vendor文件里面。

一般引用vendor里面的类或者插件用vendor();

里面加载的就是vendor文件,然后想要加载哪个文件,直接写就行,中间的“.”相当于文件路径的“/”。

例如加载excel5这个文件:

先把html代码贴出来(整个导入导出的):

    <form enctype="multipart/form-data" method="post" id="form-admin-role-add">
        <div class="form-group col-sm-2">
            <input type="file" name="file_stu" />
        </div>
        <div class="form-group col-sm-2">
            <input type="submit" value="导入" class="btn btn-w-m btn-primary btn-outline" />
        </div>
    </form>

    <div class="form-group col-sm-2">
        <a class="btn btn-w-m btn-primary btn-outline" href="{:url(‘EquipmentList/out‘)}">下载excel表格</a>
    </div>

这里有个要注意的地方,我导入是做了异步的,导出不能做异步。

然后先放导入的方法吧:

//导入Excel
    public function into()
    {
        if (!empty ($_FILES [‘file_stu‘] [‘name‘])) {
            $tmp_file = $_FILES [‘file_stu‘] [‘tmp_name‘];
            $file_types = explode(".", $_FILES [‘file_stu‘] [‘name‘]);
            $file_type = $file_types [count($file_types) - 1];
            /*判别是不是.xls文件,判别是不是excel文件*/
            if (strtolower($file_type) != "xlsx") {
                $this->error(‘不是Excel文件,重新上传‘);
            }
            /*设置上传路径*/
            /*百度有些文章写的上传路径经过编译之后斜杠不对。不对的时候用大写的DS代替,然后用连接符链接就可以拼凑路径了。*/
            $savePath = ROOT_PATH . ‘public‘ . DS . ‘uploads‘ . DS;/*以时间来命名上传的文件*/
            $str = date(‘Ymdhis‘);
            $file_name = $str . "." . $file_type;

            /*是否上传成功*/

            if (!copy($tmp_file, $savePath . $file_name)) {
                $this->error(‘上传失败‘);
            }
            /*
            *对上传的Excel数据进行处理生成编程数据,这个函数会在下面第三步的ExcelToArray类中
            *注意:这里调用执行了第三步类里面的read函数,把Excel转化为数组并返回给$res,再进行数据库写入
            */
            require THINK_PATH.‘library/think/ExcelToArrary.php‘;//导入excelToArray类
          //引入这个类试了百度出来的好几个方法都不行。最后简单粗暴的使用了require方式。这个类想放在哪里放在哪里。只要路径对就行。

            $ExcelToArrary = new ExcelToArrary();//实例化

            $res=$ExcelToArrary->read($savePath.$file_name,"UTF-8",$file_type);//传参,判断office2007还是office2003

            /*对生成的数组进行数据库的写入*/
            foreach ($res as $k => $v) {
                if ($k > 1) {
                    $data[$k][‘pname‘] = $v[0];
                    $data[$k][‘access‘] = $v[1];
                   $data[$k][‘jointime‘] = time();
                }
            }

            //插入的操作最好放在循环外面

            $result = model(‘ProductAccess‘)->insertAll($data);

            if($result){
                return [‘state‘=>true, ‘msg‘=>‘导入成功‘];
            }else{
                return [‘state‘=>false, ‘msg‘=>‘导入失败‘];
            }

        }

    }

这里面有要引入ExcelToArray,代码如下:

<?php
namespace think;

use PHPExcel_IOFactory;
use PHPExcel_Cell;
use PHPExcel;
/**
 * 读取Excel数据
 */
class ExcelToArrary
{
    public function __construct() {
        //这些文件需要下载phpexcel,然后放在vendor文件里面。具体参考上一篇数据导出。
        vendor("PHPExcel.PHPExcel.PHPExcel");
        vendor("PHPExcel.PHPExcel.Writer.IWriter");
        vendor("PHPExcel.PHPExcel.Writer.Abstract");
        vendor("PHPExcel.PHPExcel.Writer.Excel5");
        vendor("PHPExcel.PHPExcel.Writer.Excel2007");
        vendor("PHPExcel.PHPExcel.IOFactory");
    }

    public function read($filename,$encode,$file_type){
            if(strtolower ( $file_type )==‘xls‘)//判断excel表类型为2003还是2007
            {
                Vendor("Excel.PHPExcel.Reader.Excel5");
                $objReader = PHPExcel_IOFactory::createReader(‘Excel5‘);
                $objReader = PHPExcel_IOFactory::createReader(‘Excel5‘);

            }elseif(strtolower ( $file_type )==‘xlsx‘)
            {
                Vendor("Excel.PHPExcel.Reader.Excel2007");
                $objReader = PHPExcel_IOFactory::createReader(‘Excel2007‘);
            }
            $objReader->setReadDataOnly(true);
            $objPHPExcel = $objReader->load($filename);
            $objWorksheet = $objPHPExcel->getActiveSheet();
            $highestRow = $objWorksheet->getHighestRow();
            $highestColumn = $objWorksheet->getHighestColumn();
            $highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn);
            $excelData = array();
            for ($row = 1; $row <= $highestRow; $row++) {
                for ($col = 0; $col < $highestColumnIndex; $col++) {
                    $excelData[$row][] =(string)$objWorksheet->getCellByColumnAndRow($col, $row)->getValue();
                    }
            }
            return $excelData;
    }

}

只要类都引入成功了,代码直接贴上去就能用了

这里改成你自己的。导入就完成啦。

然后就是导出。

//导出Excel
    public function out()
    {

        //导出
        $path = dirname(__FILE__); //找到当前脚本所在路径
        vendor("PHPExcel.PHPExcel.PHPExcel");
        vendor("PHPExcel.PHPExcel.Writer.IWriter");
        vendor("PHPExcel.PHPExcel.Writer.Abstract");
        vendor("PHPExcel.PHPExcel.Writer.Excel5");
        vendor("PHPExcel.PHPExcel.Writer.Excel2007");
        vendor("PHPExcel.PHPExcel.IOFactory");
        $objPHPExcel = new \PHPExcel();
        $objWriter = new \PHPExcel_Writer_Excel5($objPHPExcel);
        $objWriter = new \PHPExcel_Writer_Excel2007($objPHPExcel);

        // 实例化完了之后就先把数据库里面的数据查出来
        $sql = model(‘ProductAccess‘)->select();

        // 设置表头信息
        $objPHPExcel->setActiveSheetIndex(0)
        ->setCellValue(‘A1‘, ‘机型‘)
        ->setCellValue(‘B1‘, ‘机型编号‘)
        ->setCellValue(‘C1‘, ‘生产日期‘);

        /*--------------开始从数据库提取信息插入Excel表中------------------*/

        $i=2;  //定义一个i变量,目的是在循环输出数据是控制行数
        $count = count($sql);  //计算有多少条数据
        for ($i = 2; $i <= $count+1; $i++) {
            $objPHPExcel->getActiveSheet()->setCellValue(‘A‘ . $i, $sql[$i-2][‘pname‘]);
            $objPHPExcel->getActiveSheet()->setCellValue(‘B‘ . $i, $sql[$i-2][‘access‘]);
            $objPHPExcel->getActiveSheet()->setCellValue(‘C‘ . $i, $sql[$i-2][‘jointime‘]);
        }

        /*--------------下面是设置其他信息------------------*/

        $objPHPExcel->getActiveSheet()->setTitle(‘productaccess‘);      //设置sheet的名称
        $objPHPExcel->setActiveSheetIndex(0);                   //设置sheet的起始位置
        $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, ‘Excel5‘);   //通过PHPExcel_IOFactory的写函数将上面数据写出来

        $PHPWriter = \PHPExcel_IOFactory::createWriter( $objPHPExcel,"Excel2007");

        header(‘Content-Disposition: attachment;filename="设备列表.xlsx"‘);
        header(‘Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet‘);

        $PHPWriter->save("php://output"); //表示在$path路径下面生成demo.xlsx文件

    }

这部分相应改成自己的就成了。

我做这个,遇到的问题也基本就是类引入不成功。只要都引入成功了。就改相应代码就OK了。

时间: 2024-11-10 16:23:49

thinkphp5 使用PHPExcel 导入导出的相关文章

PHPExcel导入导出

慕课教程 -- PHPExcel导入导出 一.PHPExcel导出操作 1.快速入门 <?php #找到当前脚本的路径 $dir = dirname(__FILE__); #引入PHPExcel插件文件 require $dir."/excel/PHPExcel.php"; #实例化PHPExcel类 $objPHPExcel = new PHPExcel(); #获得当前活动sheet的操作对象 $objSheet = $objPHPExcel->getActiveShe

使用PHPExcel导入导出excel格式文件

使用PHPExcel导入导出excel格式文件 作者:zccst 由于导出使用较多,下面是导出实现过程. 第一步,将PHPExcel的源代码复制到项目的lib下 文件包括:PHPExcel.php 和 文件夹PHPExcel 源代码见附件 注1:源代码是zip格式,能在windows和linux通用. 注2:PHPExcel.zip是干净代码,可以直接引用.PHPExcel2.zip有svn记录,不适合直接引用. 第二步:在需要导出的handler页面中引用 1,在头部引入三个文件 Php代码 

phpexcel 导入导出

导出excel /** * 以下是使用示例,对于以 //// 开头的行是不同的可选方式,请根据实际需要 * 打开对应行的注释. * 如果使用 Excel5 ,输出的内容应该是GBK编码. */ //require_once 'PHPExcel.php'; // uncomment ////require_once 'PHPExcel/Writer/Excel5.php'; // 用于其他低版本xls // or ////require_once 'PHPExcel/Writer/Excel200

PHPExcel导入导出常用方法总结

最近公司后台管理系统需求,要用PHP导出excel表格数据,所以特整理了一下常用的方法供大家参考: PHPExcel扩展包地址:https://github.com/wanqianworld/phpexcel-1.8 大致的分为几个部分: 一.导出的方法及步骤 1.引入PHPExcel文件:require_once("../Classes/PHPExcel.php"); 2.实例化PHPExcel:$ObjPHPExcel = new PHPExcel(); 3.获取当前工作sheet

thinkphp5 csv格式导入导出(多数据处理)

关于csv文件格式的导出导入个人见解 先上代码: <?php namespace think; class Csv { /** * 导出csv文件 * @param $list 数据源 * @param $title 数据列表 */ public function put_csv($list,$title) { $file_name = "exam".time().".csv";//文件名 header('Content-Type: application/v

thinkphp上传至服务器后PhpExcel导入导出的若干问题

在将tp5项目上传到服务器后,原来的系统有部分功能无法实现,在批量到如时报错 mkdir(): Device or resource: 查看了一下这是权限的问题,因此打开服务器中的项目,将controller控制器中的导入代码的文件位置进行修改: 这里改为你自己定义的文件夹位置. 点开文件夹属性->安全 设置此文件夹可以让所有用户读取和写入. 设置完成再次点击导入,发现报错: Warning: "continue" targeting switch is equivalent t

PHP导入导出excel表格图片(转)

写excel的时候,我用过pear的库,也用过pack压包的头,同样那些利用smarty等作的简单替换xml的也用过,csv的就更不用谈了.呵呵.(COM方式不讲了,这种可读的太多了,我也写过利用wps等进行word等的生成之类的文章 )但是在读的时候,只用过一种,具体是什么忘了,要回去翻代码了.基本上导出的文件分为两种:1:类Excel格式,这个其实不是传统意义上的Excel文件,只是因为Excel的兼容能力强,能够正确打开而已.修改这种文件后再保存,通常会提示你是否要转换成Excel文件.优

PHP导入导出Excel方法

看到这篇文章的时候,很是惊讶原作者的耐心,虽然我们在平时用的也 有一些,但没有作者列出来的全,写excel的时候,我用过pear的库,也用过pack压包的头,同样那些利用smarty等作的简单替换xml的也用 过,csv的就更不用谈了.呵呵.(COM方式不讲了,这种可读的太多了,我也写过利用wps等进行word等的生成之类的文章 )但是在读的时候,只用过一种,具体是什么忘了,要回去翻代码了.因为采用的是拿来主义,记不住.原文地址:http://xinsync.xju.edu.cn/index.p

PHP使用PHPEXCEL导入Excel

下载PHPEXCEL 后放到项目里. ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 public function InExcel() {     //设定缓