tp5 导入phpExcel的简单demo

1、下载PHPExcel扩展包 下载地址 链接: https://pan.baidu.com/s/1v_9ywN2YWJNfDESm1NHffg 密码: 8dqt

 2、讲下载的解压并放进vendor目录,如下图

3、HTML代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>数据导入</title>
    <script type="text/javascript" src="/static/admin/lib/jquery/1.9.1/jquery.min.js"></script>
</head>
<body>
    <P><a href="/ExcelModule/phoneModule.xls">下载导入模板</a></P>
    <br/>
    <form action="__ROOT__/admin.php/Import/imp_data" method="post" enctype="multipart/form-data">
        <input type="file" name="files" id="file" />
        <input type="hidden" name="table" value="tablename" />
        <input type="submit" value="导入"/>
    </form>
</body>

代码截图

页面效果图

4、PHP代码

<?php
namespace admin\index\controller;

use think\Controller;
use \org\Auth;
use \think\Db;
use think\Request;
use \admin\index\Model;
use \think\Session;
class Import extends Controller
{

    public function __construct(){
        parent::__construct();
        
    }
    /**
     * 数据导入
     * @return mixed
     */
    public function index(){
        
        return $this->fetch();
    }
    
    public function imp_data(){
        //获取表单上传文件
        $file = $this->request->file('files');
        $info = $file->move(ROOT_PATH . 'public' . DS . 'Excel');
        //移动到框架应用根目录
        if ($info) {
            

            $file_name = ROOT_PATH . 'public' . DS . 'excel' . DS . $info->getsaveName();
            // dump($file_name);
            $extension = strtolower(pathinfo($file_name, PATHINFO_EXTENSION)); //判断导入表格后缀格式
            // dump($extension);die;
            vendor("PHPExcel.PHPExcel");
            $objPHPExcel = new \PHPExcel();
            // $objReader = \PHPExcel_IOFactory::createReader('Excel2007');
            $objReader = \PHPExcel_IOFactory::createReader('Excel5');
            $obj_PHPExcel = $objReader->load($file_name, $encode = 'utf-8');  //加载文件内容,编码utf-8

            $excel_array = $obj_PHPExcel->getsheet(0)->toArray();   //转换为数组格式
            array_shift($excel_array);  //删除第一个数组(标题);
            // dump($excel_array);die;

            $pcNum = date('Ymd') . str_pad(mt_rand(1, 99999), 5, '0', STR_PAD_LEFT);
            foreach ($excel_array as $key => $value) {
                $data['utel1'] = $value[0];
                $data['uname'] = $value[1];
                $data['uremark'] = $value[2];
                $data['ucol1'] = $value[3];
                $data['ucol2'] = $value[4];
                $data['ucol3'] = $value[5];
                $data['ucol4'] = $value[6];
                $data['ucol5'] = $value[7];
                $data['ucol6'] = $value[8];
                $data['ucol7'] = $value[9];
                $data['ucol8'] = $value[10];
                $data['ucol9'] = $value[11];
                $data['ucol10'] = $value[12];
                $data['upc'] = $pcNum;
                $data['uaddtime'] = date('Y-m-d H:i:s', time());
                // $data['entid'] = $_SESSION['user']['entid'];
                // $data['workno'] = $_SESSION['user']['workno'];
                $res = Db::table('cti_phone')->insert($data);
            }
            if($res){
                $this->success('导入成功!');
            }
        }else{
            //上传失败获取错误信息
            $this->error($file->getError());
        }

    }

}

猜你喜欢

转载自blog.csdn.net/lfbin5566/article/details/81219572