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());
        }

    }

}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章