Home >Backend Development >PHP Tutorial >TP5 (layui) excel import

TP5 (layui) excel import

藏色散人
藏色散人forward
2019-07-23 14:29:414776browse

1.composer installation PHPExcel

Download and install composer

Secondly switch cmd to the project root directory and run the command:

composer require phpoffice/phpexcel

Note :

1. When running OpenSSL, you may get an error. Go to php.ini and open the extension=php_openssl.dll extension and remove the semicolon.

2. It is still possible. There is an error that the matching package cannot be found. This is because I use the nts version of phpstudy locally. This version is special and supports both apache and nginx. It is only the PHP version used for local virtual environment development and testing, so it cannot be matched and should be switched. The normal version is installed by running the command

2. Front-end code

<div class="layui-form-item" >
<label class="layui-form-label">导入专线</label>
<div class="layui-input-inline">
<div class="layui-upload">
<button type="button" name="myfile" class="layui-btn" id="myfile"><i class="layui-icon"></i>上传文件</button>
</div>
</div>
</div>
<script type="text/javascript">
    layui.use([&#39;form&#39;,&#39;upload&#39;],function(){
        var form=layui.form;
        var upload=layui.upload;
        upload.render({ //允许上传的文件后缀
            elem: &#39;#myfile&#39;
            ,url: "{:url(&#39;Logisticscompany/inserline&#39;)}"
            ,accept: &#39;file&#39; //普通文件
            ,exts: &#39;xls|excel|xlsx&#39; //只允许上传压缩文件
            ,done: function(res){
                if(res.code==1){
                    layer.msg(&#39;上传成功,已解析数据&#39;,{icon:6});
                    location.href="{:url(&#39;Logisticscompany/lists&#39;)}";
                }else{
                    layer.msg(&#39;解析失败&#39;,{icon:5});
                }
            }
        });
        form.on(&#39;submit(formsub)&#39;,function(data){
            layer.msg(&#39;导入数据具体详情未协商确认,待确认后处理&#39;);
            return false;
        })
    })
</script>

3.controller

  /**
     * excel导入网点
     */
    public function  insert(){
        if(request() -> isPost())
        {
            vendor("PHPExcel.PHPExcel"); //方法一
            $objPHPExcel =new \PHPExcel();
            //获取表单上传文件
            $file = request()->file(&#39;file&#39;);
            $info = $file->validate([&#39;ext&#39; => &#39;xlsx,xls&#39;])->move(ROOT_PATH . &#39;public&#39;);  //上传验证后缀名,以及上传之后移动的地址  E:\wamp\www\bick\public
            if($info)
            {
                $exclePath = $info->getSaveName();  //获取文件名
                $file_name = ROOT_PATH . &#39;public&#39; . DS . $exclePath;//上传文件的地址
                $file_types = explode ( ".", $_FILES [&#39;file&#39;] [&#39;name&#39;] );
                $file_type = $file_types [count ( $file_types ) - 1];
                if($file_type==&#39;xls&#39;){
                    $objReader =\PHPExcel_IOFactory::createReader("Excel5");
                }
                else if($file_type==&#39;xlsx&#39;){
                    $objReader =\PHPExcel_IOFactory::createReader("Excel2007");
                }
                $obj_PHPExcel =$objReader->load($file_name, $encode = &#39;utf-8&#39;);  //加载文件内容,编码utf-8
                $excel_array=$obj_PHPExcel->getSheet(0)->toArray();   //转换为数组格式
                array_shift($excel_array);  //删除第一个数组(标题);
                $data = [];
                $i=0;
                foreach($excel_array as $k=>$v) {
                    $data[$k][&#39;viewName&#39;] = $v[0];
                    $data[$k][&#39;cityId&#39;] = $v[1];
                    $data[$k][&#39;stationAddress&#39;] = $v[2];
                    $data[$k][&#39;linkMan&#39;] = $v[3];
                    $data[$k][&#39;linkPhone&#39;] = $v[4];
                    $data[$k][&#39;longitude&#39;] = $v[5];
                    $data[$k][&#39;latitude&#39;] = $v[6];
                    $data[$k][&#39;userId&#39;] = $v[7];
                    $data[$k][&#39;remark&#39;] = $v[8];
                    $i++;
                }
                $re=    Db::name("htt_freightstation")->insertAll($data);
                if($re){
                    $msg=[
                        &#39;code&#39;=>1,
                        &#39;msg&#39;=>&#39;已获取信息&#39;,
                    ];
                    return json_encode($msg);
                }
                else{
                    $msg=[
                        &#39;code&#39;=>0,
                        &#39;msg&#39;=>&#39;获取信息失败&#39;,
                    ];
                    return json_encode($msg);
                }
            }else
            {
                echo $file->getError();
            }
        }
        return $this->fetch(&#39;lists&#39;);
    }

The above is the detailed content of TP5 (layui) excel import. For more information, please follow other related articles on the PHP Chinese website!

Statement:
This article is reproduced at:cnblogs.com. If there is any infringement, please contact admin@php.cn delete