ThinkPhp5.1 + PHPExcel-Produktionsdatenimport

XuPing.Yang
Freigeben: 2022-02-17 10:11:05
Original
2372 Leute haben es durchsucht

Der Datenimport ist an vielen Stellen erforderlich. Wie führt man den Datenimport mit ThinkPhp5.1 durch?

1 Vorbereitung

Der Editor implementiert den Datenimport über PHPExcel, daher müssen Sie vor der Produktion zunächst PHPExcel-bezogene Komponenten herunterladen. Derzeit unterstützt tp5.1 die Composer-Installation und der Editor hat die PHPExcel-Komponente über Composer installiert. [Empfohlen: thinkphp-Video-Tutorial]

Vor der Installation müssen Sie zunächst sicherstellen, dass Sie die Composer-Komponente auf Ihrem Computer haben. Wenn Composer noch nicht installiert ist, können Sie den folgenden Befehl unter Linux und Mac OS X ausführen:

curl -sS https://getcomposer.org/installer | php
mv composer.phar /usr/local/bin/composer
Nach dem Login kopieren

Unter Windows müssen Sie Composer-Setup.exe herunterladen und ausführen, Download-Adresse:

https://www.kancloud.cn/manual/thinkphp5_1/353948

Nach der Installation von Composer müssen Sie PHPExcel installieren , win+R, öffnen Führen Sie die Schnittstelle aus, geben Sie cmd ein, rufen Sie die Verwaltungsschnittstelle auf, geben Sie den Laufwerksbuchstaben ein, in dem sich Ihr Projekt befindet (hier nehmen Sie das Laufwerk D als Beispiel, das Projekt befindet sich in D:phpstudy_proWWWmyapp.io) und Klicken Sie dann auf Eingabe:

ThinkPhp5.1 + PHPExcel-Produktionsdatenimport

Eingabe: cd D: phpstudy_proWWWmyapp.io, suchen Sie das Verzeichnis, in dem sich das Projekt befindet

ThinkPhp5.1 + PHPExcel-Produktionsdatenimport

Der nächste Schritt besteht darin, das PHPExcel-Plug-in zu installieren, geben Sie ein: Composer erfordert phpoffice/phpexcel , klicken Sie auf die Eingabetaste, um mit der Installation von PHPExcel zu beginnen.

2 Front-End-Einreichungsseite

html

<form class="layui-form" enctype="multipart/form-data">
    <input type="hidden" name="type_id" value="{$type_id}">
    <div class="layui-form-item" style="margin-left: 42px;">
        <div class="layui-input-inline" style="width: 122px;">
            <button type="button" class="layui-btn" name="file" lay-verify="file" id="test3"><i class="layui-icon"></i>上传文件</button>
        </div>
    </div>
    <div class="layui-form-item" style="margin-left: 42px;">
        <div class="layui-input-inline">
            <button  class="layui-btn" lay-filter="add" lay-submit="add">
                导入
            </button>
        </div>
    </div>
    <div class="layui-form-item">
        <div class="layui-input-block">
            <div style="line-height: 35px;">
                注:
                <p>1.文件大小:请上传小于10M的文件</p>
                <p>2.文件类型:上传时首先
                    <span class="common-a">
                <a href="/import/member.xlsx">下载导入模板</a>
            </span>,填好信息后上传</p>
            </div>
        </div>
    </div>
</form>
Nach dem Login kopieren

js

<script>
    layui.use([&#39;form&#39;, &#39;layer&#39;,&#39;upload&#39;], function () {
        $ = layui.jquery;
        var form = layui.form
            , layer = layui.layer;

        var $ = layui.jquery,
            upload = layui.upload;

        upload.render({
            elem: &#39;#test3&#39;
            ,url: &#39;你的上传路径&#39;
            ,accept: &#39;file&#39; //普通文件
            ,exts: &#39;xls|xlsx&#39;
            ,size:&#39;10240&#39;
            ,done: function(res){
                $(&#39;#test3&#39;).append(&#39;<input type="text" name="file" id="file" lay-verify="file" value="&#39;+res.data +&#39;" />&#39;)
            }
        });
        //监听提交
        form.on(&#39;submit(add)&#39;, function(data){
            console.log(data);
            //发异步,把数据提交给php
            $.post(&#39;{:url(\&#39;saveImportMember\&#39;)}&#39;,$(&#39;form&#39;).serialize(),function(data){
                if(data.res == 1){
                    layer.msg(data.msg);
                    setTimeout(function(){parent.window.location.reload();},1000);
                }else if(data.res == 0){
                    layer.alert(data.msg,{icon: 2});
                }else{
                    layer.alert(&#39;操作失败&#39;,{icon: 2});
                }
            })
            return false;
        });
    });
</script>
Nach dem Login kopieren

3 Hintergrundverarbeitung

Hier ist ein Beispiel für das Hochladen einer Mitgliederinformationstabelle. Die Feldwerte umfassen Hrsg sind: Name (Name), Geschlecht (Sex), Mitgliedschaftstyp (Type_ID), ID-Nummer (Identität), Mitgliedsnummer (Nummer), Kontaktnummer (Telefon), Sortierung (Sortierung), Mitgliedsstatus (Status).

//上传excel文件
$file = Request::param(&#39;file&#39;);
//获取文件路径
$filePath = Env::get(&#39;root_path&#39;).&#39;public&#39;.DIRECTORY_SEPARATOR.$file;
if($filePath == &#39;&#39;){
    return [&#39;res&#39;=>0,&#39;msg&#39;=>&#39;你上传的文件为空&#39;];
}
$suffix = $this->DbSy->GetFileExt($file);
//判断哪种类型
if($suffix=="xlsx"){
    $reader = \PHPExcel_IOFactory::createReader(&#39;Excel2007&#39;);
}else{
    $reader = \PHPExcel_IOFactory::createReader(&#39;Excel5&#39;);
}
//载入excel文件
$excel = $reader->load("$filePath",$encode = &#39;utf-8&#39;);
//读取第一张表
$sheet = $excel->getSheet(0);
//获取总行数
$row_num = $sheet->getHighestRow();
//获取总列数
$col_num = $sheet->getHighestColumn();
$time = time();
$data = []; //数组形式获取表格数据
$count = 0;
$total = 0;
$error_count = 0;
for ($i = 2; $i <= $row_num; $i ++) {
    $type_id = Request::param(&#39;type_id&#39;);
    $data[&#39;type_id&#39;] = $type_id;
    $name = $sheet->getCell("A".$i)->getValue();
    $sex = $sheet->getCell("B".$i)->getValue();
    $identity = $sheet->getCell("C".$i)->getValue();
    $telephone = $sheet->getCell("F".$i)->getValue();
    $data[&#39;sort&#39;] = $this->DbSy->getSort(5,&#39;sort desc&#39;,array(&#39;type_id&#39;=>$type_id));
    if(!$identity){
        return [&#39;res&#39;=>0,&#39;msg&#39;=>&#39;身份证号不能为空&#39;];
    }
    $data[&#39;identity&#39;] = $identity;
    if(!$name){
        return [&#39;res&#39;=>0,&#39;msg&#39;=>&#39;姓名不能为空&#39;];
    }
    $data[&#39;name&#39;] = $name;
    if($sex==&#39;男&#39;){
        $data[&#39;sex&#39;] = 1;
    }elseif ($sex==&#39;女&#39;){
        $data[&#39;sex&#39;] = 2;
    }else{
        $data[&#39;sex&#39;] = 3;
    }
    $data[&#39;identity&#39;] = $identity;
    $data[&#39;number&#39;] = $this->DbSy->getNumber(5,&#39;sort desc&#39;,array(&#39;type_id&#39;=>$type_id));
   
    if($telephone){
        $data[&#39;telephone&#39;] = $telephone;
    }else{
        $data[&#39;telephone&#39;] = &#39;&#39;;
    }
    $data[&#39;status&#39;] = 5;
    $member = $this->DbSy->FindWhere(5,array(&#39;name&#39;=>$name,&#39;identity&#39;=>$identity,&#39;type_id&#39;=>$type_id));
    if($member){
        /*$data[&#39;updatetime&#39;] = time();*/
        $info = $this->DbSy->editContent(5,$data,array(&#39;id&#39;=>$member[&#39;id&#39;]));
        if($info){
            $total++;
        }
    }else{
        // 读取单元格
        $data[&#39;addtime&#39;] = time();
        $data[&#39;updatetime&#39;] = time();
        $info = $this->DbSy->insertGetId(5,$data);
        if($info){
            $count++;
        }else{
            $error_count++;
        }
    }
}
$msg =  "成功导入".$count."条数据,重复".$total."条数据,导入失败".$error_count."条数据";
if($count > 0){
    return [&#39;res&#39;=>1,&#39;msg&#39;=>$msg];
}else{
    return [&#39;res&#39;=>0,&#39;msg&#39;=>$msg];
}
Nach dem Login kopieren

Das Obige ist die Zusammenfassung aller Prozesse zum Importieren von Informationen mit TP5.1+PHPExcel. Ich hoffe, dass es für alle hilfreich ist.

Das obige ist der detaillierte Inhalt vonThinkPhp5.1 + PHPExcel-Produktionsdatenimport. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
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