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