Heim > Backend-Entwicklung > PHP-Tutorial > TP5 (layui) Excel-Import

TP5 (layui) Excel-Import

藏色散人
Freigeben: 2023-04-07 06:30:01
nach vorne
4782 Leute haben es durchsucht

1.composer installiert PHPExcel

Composer herunterladen und installieren

Zweitens wechselt cmd in das Stammverzeichnis des Projekts und führt den Befehl aus:

composer require phpoffice/phpexcel
Nach dem Login kopieren

Hinweis:

1. Beim Ausführen von OpenSSL oder ähnlichem wird möglicherweise eine Fehlermeldung angezeigt. Gehen Sie zu php.ini, öffnen Sie die Erweiterung extension=php_openssl.dll und entfernen Sie das Semikolon >

2. Es ist immer noch möglich, dass das passende Paket nicht gefunden wird. Dies liegt daran, dass ich die nts-Version von phpstudy lokal verwende. Diese Version ist speziell und unterstützt sowohl Apache als auch Nginx Die PHP-Version wird für die Entwicklung und das Testen lokaler virtueller Umgebungen verwendet und kann daher nicht angepasst werden. Die normale Version wird durch Ausführen des Befehls


2 installiert 🎜>

<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>
Nach dem Login kopieren
<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>
Nach dem Login kopieren

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;);
    }
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonTP5 (layui) Excel-Import. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:cnblogs.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage