PHP 프레임워크 ThinkPHP ThinkPhp5.1 + PHPExcel 프로덕션 데이터 가져오기

ThinkPhp5.1 + PHPExcel 프로덕션 데이터 가져오기

Feb 16, 2022 pm 05:29 PM
phpexcel thinkphp5.1

데이터 가져오기는 여러 곳에서 필요합니다. ThinkPhp5.1을 사용하여 데이터 가져오기를 수행하는 방법 다음으로 편집기에서 전체 프로세스를 이해하도록 안내합니다.

1 준비

편집기는 PHPExcel을 통해 데이터 가져오기를 구현하므로 제작 전에 먼저 PHPExcel 관련 구성요소를 다운로드해야 합니다. 현재 tp5.1은 Composer 설치를 지원하며, 편집자는 Composer를 통해 PHPExcel 구성요소를 설치합니다. [권장: thinkphp 비디오 튜토리얼]

설치하기 전에 먼저 컴퓨터에 Composer 구성 요소가 있는지 확인해야 합니다. Composer가 아직 설치되지 않은 경우 Linux 및 Mac OS X에서 다음 명령을 실행할 수 있습니다.

curl -sS https://getcomposer.org/installer | php
mv composer.phar /usr/local/bin/composer
로그인 후 복사

Windows에서는 Composer-Setup.exe를 다운로드하여 실행해야 합니다. 다운로드 주소:

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

Composer 설치 후 PHPExcel을 설치해야 합니다. , win+R, 인터페이스 실행 열기, cmd 입력, 관리 인터페이스 입력, 프로젝트가 있는 드라이브 문자 입력(여기서는 D 드라이브를 예로 들어, 프로젝트는 D:phpstudy_proWWWmyapp.io에 있음) Enter를 클릭하세요:

ThinkPhp5.1 + PHPExcel 프로덕션 데이터 가져오기

입력: cd D: phpstudy_proWWWmyapp.io, 프로젝트가 있는 디렉토리를 찾으세요

ThinkPhp5.1 + PHPExcel 프로덕션 데이터 가져오기

다음 단계는 PHPExcel 플러그인을 설치하는 것입니다. 다음을 입력하세요: Composer require phpoffice/phpexcel, Enter를 클릭하여 PHPExcel 설치를 시작합니다.

2 프론트엔드 제출 페이지

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>
로그인 후 복사

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>
로그인 후 복사

3 백그라운드 처리

다음은 회원 정보 테이블 업로드 예시입니다. 이름( name), 성별(sex), 회원유형(type_id), 아이디번호(identity), 회원번호(number), 연락처(전화번호), 정렬(sort), 회원상태(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];
}
로그인 후 복사

위는 TP5.1+PHPExcel을 사용하여 정보를 가져오는 모든 과정에 대한 편집자의 요약입니다. 모든 분들께 도움이 되기를 바랍니다.


위 내용은 ThinkPhp5.1 + PHPExcel 프로덕션 데이터 가져오기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

전체 가이드: PHP 확장 PHPExcel을 사용하여 Excel 파일을 처리하는 방법 전체 가이드: PHP 확장 PHPExcel을 사용하여 Excel 파일을 처리하는 방법 Jul 28, 2023 pm 10:01 PM

전체 가이드: PHP 확장을 사용하여 Excel 파일을 처리하는 방법 PHPExcel 소개: Excel 파일은 대용량 데이터 처리 및 통계 분석 시 데이터 저장 및 교환을 위한 일반적인 형식으로 사용되는 경우가 많습니다. PHP 확장 PHPExcel을 사용하면 Excel 파일을 쉽게 읽고, 쓰고, 수정하여 Excel 데이터를 효과적으로 처리할 수 있습니다. 이 기사에서는 PHP 확장 PHPExcel을 사용하여 Excel 파일을 처리하고 코드 예제를 제공하는 방법을 소개합니다. 1. PHPExc 설치

PHP 개발: PHPExcel을 사용하여 Excel 파일 처리 PHP 개발: PHPExcel을 사용하여 Excel 파일 처리 Jun 15, 2023 pm 03:45 PM

디지털 시대의 도래와 함께 데이터는 우리의 일상과 업무에서 가장 중요한 부분이 되었고, 엑셀 파일은 데이터 처리를 위한 중요한 도구 중 하나가 되었습니다. 나는 많은 PHP 개발자들이 직장에서 데이터 처리 및 작업을 위해 Excel 파일을 사용하는 경우를 자주 접하게 될 것이라고 생각합니다. 이 글에서는 PHPExcel 라이브러리를 사용하여 Excel 파일을 처리하는 방법과 주의사항을 소개합니다. PHPExcel이란 무엇입니까? PHPExcel은 PHP 클래스입니다.

phpexcel을 사용하여 Excel 파일을 CSV 파일로 변환하고 여는 방법 phpexcel을 사용하여 Excel 파일을 CSV 파일로 변환하고 여는 방법 Mar 27, 2023 pm 04:16 PM

PHPEXCEL은 Excel 파일을 읽고 쓰는 데 탁월한 PHP 클래스 라이브러리입니다. PHP를 사용하여 Excel 파일을 읽고 쓸 수 있는 매우 충분한 API를 제공합니다. 경우에 따라 사용하기 위해 Excel 파일을 CSV 파일로 변환해야 하는 경우가 있습니다. 그래서 이번 글에서는 PHPEXCEL 클래스 라이브러리를 사용하여 엑셀 파일을 CSV 파일로 변환하고 여는 방법을 주로 설명합니다.

phpexcel이 PHP 개발자의 초점이 된 이유 phpexcel이 PHP 개발자의 초점이 된 이유 Mar 27, 2023 pm 06:15 PM

PHPExcel은 Microsoft Excel 파일을 처리하기 위한 오픈 소스 PHP 라이브러리로 Excel 파일을 읽고, 만들고, 수정하고 저장할 수 있습니다. 데이터 분석, 보고서 생성, 데이터 가져오기 및 내보내기 등과 같은 작업을 처리하는 데 사용할 수 있는 강력하고 고도로 사용자 정의 가능한 도구입니다. 이 기사에서는 PHPExcel이 PHP 개발자의 중심이 된 이유를 소개합니다.

PHPExcel을 사용하여 Excel 파일을 처리하는 방법은 무엇입니까? PHPExcel을 사용하여 Excel 파일을 처리하는 방법은 무엇입니까? Jun 01, 2023 pm 02:01 PM

PHPExcel은 Microsoft Excel(.xls 및 .xlsx) 파일을 처리하기 위한 오픈 소스 PHP 라이브러리입니다. 엑셀 파일을 읽고 쓰고 조작할 수 있으며, 다양한 기능과 방법을 제공합니다. PHP 프로젝트에서 PHPExcel 라이브러리를 사용하면 Excel 파일을 빠르고 쉽게 처리하고 데이터 가져오기, 내보내기, 데이터 처리 등의 기능을 구현할 수 있습니다. 이 기사에서는 PHPExcel을 사용하여 Excel 파일을 처리하는 방법을 소개합니다. 1. PHPExcel을 설치하려면 다음을 사용하십시오.

PHP 및 PHPExcel을 사용하여 Excel 파일 만들기 PHP 및 PHPExcel을 사용하여 Excel 파일 만들기 May 11, 2023 am 08:40 AM

오늘날 급속한 정보 전송 시대에 데이터 처리 및 저장은 점점 더 중요해지고 있습니다. 많은 사람들이 엑셀 테이블을 가장 먼저 선택하는 이유는 엑셀 테이블이 다양한 데이터를 통합할 수 있고 쉽게 분석하고 처리할 수 있기 때문입니다. Excel 테이블 생성을 보다 효율적으로 완료하기 위해 PHP와 PHPExcel이라는 두 가지 강력한 도구를 사용할 수 있습니다. 이번 글에서는 PHP와 PHPExcel을 사용하여 Excel 파일을 만드는 방법을 소개하겠습니다. 1. 먼저 PHPExcel을 설치하세요

PHP 개발 팁: PHPExcel 및 PHPExcel_IOFactory를 사용하여 MySQL 데이터베이스를 작동하는 방법 PHP 개발 팁: PHPExcel 및 PHPExcel_IOFactory를 사용하여 MySQL 데이터베이스를 작동하는 방법 Jul 02, 2023 pm 02:28 PM

PHP 개발 팁: PHPExcel 및 PHPExcel_IOFactory를 사용하여 MySQL 데이터베이스를 작동하는 방법 개요: 웹 개발에서 Excel 파일을 처리하는 것은 일반적이고 중요한 작업입니다. PHPExcel은 Excel 파일을 읽고 쓰는 데 도움이 되는 강력하고 사용하기 쉬운 PHP 라이브러리입니다. 이 기사에서는 PHPExcel 및 PHPExcel_IOFactory 라이브러리를 사용하여 MySQL 데이터베이스를 작동하는 방법을 소개합니다. 1 단계

PHP 개발 기술: PHPExcel을 사용하여 MySQL 데이터베이스를 작동하는 방법 PHP 개발 기술: PHPExcel을 사용하여 MySQL 데이터베이스를 작동하는 방법 Jul 02, 2023 pm 12:21 PM

PHP 개발 기술: PHPExcel을 사용하여 MySQL 데이터베이스를 운영하는 방법 인터넷의 활발한 발전으로 인해 데이터베이스에 많은 양의 데이터가 저장되고 가져오기, 내보내기 및 처리와 같은 작업이 필요합니다. PHP 개발에서 PHPExcel은 Excel 파일과의 상호 작용을 단순화하고 데이터 가져오기 및 내보내기를 실현할 수 있는 강력한 라이브러리입니다. 이 기사에서는 PHPExcel을 사용하여 MySQL 데이터베이스를 작동하고 데이터 가져오기 및 내보내기 기능을 구현하는 방법을 소개합니다. PHPExcel 설치 및 구성

See all articles