Home Backend Development PHP Tutorial PHP batch imports data from excel files into the database

PHP batch imports data from excel files into the database

Nov 22, 2016 pm 04:46 PM

While working on projects these days, I encountered a situation where data needed to be imported in batches. After the user submitted the excel form, we needed our backend to insert all the contents of the excel form information into the data table. Of course, the premise is that the information in the excel table that the user gives us must correspond to the field information in our table. The following are the steps for batch importing data in my backend.

First we need to download phpExcel

phpExcel is a PHP class library used to operate Office Excel documents. It is based on Microsoft's OpenXML standard and PHP language. You can use it to read and write spreadsheets in different formats.

If you need this class library, please contact me. My email is 823410261@qq.com.

After downloading phpExcel, the following is the coding implementation part. First, let me talk about the overall idea of ​​​​my handling.

Firstly, we need to get the data in the excel table. Secondly, we need to make the data into a format that complies with SQL specifications. The detailed processing will be shown in the following code. Finally, we need to put the obtained data together with the SQL statement. Execute in the program and insert all results into the data table.

1

2

<?php

require_once &#39;../Classes/PHPExcel.php&#39;;

Copy after login

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

function getFileExcle($value){

    $cgsdiseasesinterface = new Cgs_diseases_interface();

 

    $filePath = $value;//$value为需要导入数据的excel文件

 

    $PHPExcel = new PHPExcel();

 

    /**默认用excel2007读取excel,若格式不对,则用之前的版本进行读取*/

    $PHPReader = new PHPExcel_Reader_Excel2007();

 

    if(!$PHPReader->canRead($filePath)){

        $PHPReader = new PHPExcel_Reader_Excel5();

        if(!$PHPReader->canRead($filePath)){

            echo &#39;no Excel&#39;;

            return ;

        }

    }

 

    $PHPExcel = $PHPReader->load($filePath);

 

    /**读取excel文件中的第一个工作表*/

    $currentSheet = $PHPExcel->getSheet(0);

    /**取得最大的列号*/

    $allColumn = $currentSheet->getHighestColumn();

    /**取得一共有多少行*/

    $allRow = $currentSheet->getHighestRow();

    $row = array();

    /**从第二行开始输出,因为excel表中第一行为列名*/

    for($currentRow = 2;$currentRow <= $allRow;$currentRow++){

        /**从第A列开始输出*/

        $col = array();

        for($currentColumn= &#39;A&#39;;$currentColumn<= $allColumn; $currentColumn++){

            $val = $currentSheet->getCellByColumnAndRow(ord($currentColumn) - 65,$currentRow)->getValue();/**ord()将字符转为十进制数*/

            array_push($col,$val);

        }

        array_push($row,$col);

    }

    foreach($row as $key=>$value){

        $row[$key][1] = &#39;\&#39;&#39;.$value[1].&#39;\&#39;&#39;;

    }

    foreach($row as $key=>$value){

        $row[$key] = implode(",",$value);

    }

    $row = implode("),(",$row);

    $row = &#39;(&#39;.$row.&#39;)&#39;;

    $res = $cgsdiseasesinterface->insertDiseasesInformation($row);//该函数将数据插入到数据库中

    if($res){

        echo json_encode([&#39;code&#39; => CODE_SUCCESS, &#39;result&#39; => &#39;批量导入成功&#39;]);

    }else{

        echo json_encode([&#39;code&#39; => CODE_ERROR, &#39;result&#39; => &#39;批量导入失败&#39;]);

    }

}

Copy after login

One point here is that the main thing is because $currentRow starts from 2, so the first line should be the explanation of the corresponding field, and starting from the second line is the data we need. You can follow your own program actual need to make changes.

Here I spliced ​​all the data into strings. The advantage is that when the database is a short connection, you only need to connect to the database once, which saves time and system resources. If the database is set to a long connection, then The advantages of using string concatenation are not obvious. Of course, you can also use loops to insert data into the table. The advantage of this method is that it does not require complex splicing of data, but the disadvantage is that as I just said, it increases the running time and reduces the cost. It consumes more system resources.


Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Working with Flash Session Data in Laravel Working with Flash Session Data in Laravel Mar 12, 2025 pm 05:08 PM

Laravel simplifies handling temporary session data using its intuitive flash methods. This is perfect for displaying brief messages, alerts, or notifications within your application. Data persists only for the subsequent request by default: $request-

cURL in PHP: How to Use the PHP cURL Extension in REST APIs cURL in PHP: How to Use the PHP cURL Extension in REST APIs Mar 14, 2025 am 11:42 AM

The PHP Client URL (cURL) extension is a powerful tool for developers, enabling seamless interaction with remote servers and REST APIs. By leveraging libcurl, a well-respected multi-protocol file transfer library, PHP cURL facilitates efficient execution of various network protocols, including HTTP, HTTPS, and FTP. This extension offers granular control over HTTP requests, supports multiple concurrent operations, and provides built-in security features.

Simplified HTTP Response Mocking in Laravel Tests Simplified HTTP Response Mocking in Laravel Tests Mar 12, 2025 pm 05:09 PM

Laravel provides concise HTTP response simulation syntax, simplifying HTTP interaction testing. This approach significantly reduces code redundancy while making your test simulation more intuitive. The basic implementation provides a variety of response type shortcuts: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

PHP Logging: Best Practices for PHP Log Analysis PHP Logging: Best Practices for PHP Log Analysis Mar 10, 2025 pm 02:32 PM

PHP logging is essential for monitoring and debugging web applications, as well as capturing critical events, errors, and runtime behavior. It provides valuable insights into system performance, helps identify issues, and supports faster troubleshoot

12 Best PHP Chat Scripts on CodeCanyon 12 Best PHP Chat Scripts on CodeCanyon Mar 13, 2025 pm 12:08 PM

Do you want to provide real-time, instant solutions to your customers' most pressing problems? Live chat lets you have real-time conversations with customers and resolve their problems instantly. It allows you to provide faster service to your custom

Explain the concept of late static binding in PHP. Explain the concept of late static binding in PHP. Mar 21, 2025 pm 01:33 PM

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

Customizing/Extending Frameworks: How to add custom functionality. Customizing/Extending Frameworks: How to add custom functionality. Mar 28, 2025 pm 05:12 PM

The article discusses adding custom functionality to frameworks, focusing on understanding architecture, identifying extension points, and best practices for integration and debugging.

See all articles