TP5 (layui) Excel インポート

藏色散人
藏色散人転載
2019-07-23 14:29:414789ブラウズ

1.composer のインストール PHPExcel

composer をダウンロードしてインストールします

次に、cmd をプロジェクトのルート ディレクトリに切り替えて、コマンド

composer require phpoffice/phpexcel

を実行します。 注 :

1. OpenSSL の実行時にエラーが発生する場合があります。php.ini に移動し、extension=php_openssl.dll 拡張子を開いてセミコロンを削除してください。
#2. まだ可能です。一致するパッケージが見つからないというエラーが発生します。これは、phpstudy の nts バージョンをローカルで使用しているためです。このバージョンは特別で、Apache と nginx の両方をサポートしています。PHP のみです。ローカル仮想環境の開発とテストに使用されるバージョンであるため、一致することができないため、切り替える必要があります。通常のバージョンは、コマンド


2 を実行することでインストールされます。フロントエンド コード

<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.コントローラー

  /**
     * 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;);
    }

以上がTP5 (layui) Excel インポートの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はcnblogs.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。