tp5 导入phpExcel的简单demo

本文介绍如何使用PHPExcel扩展包实现从Excel文件中导入数据到数据库的过程。包括PHPExcel的安装配置、HTML表单设置及PHP代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

木子李0531

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值