phpapi接收excel文件,php讀取excel文件

本文目錄一覽:

如何用PHPExcel讀取超大excel文件

上一篇文章介紹了php-excel-reader讀取excel文件的方法,因為需要,將excel這樣的數據:新建數據庫表如下:– 數據庫: `alumni`– 表的結構 `alumni`CREATE TABLE IF NOT EXISTS `alumni` (`id` bigint(20) NOT NULL AUTO_INCREMENT,`gid` varchar(20) DEFAULT NULL COMMENT ‘檔案編號’,`student_no` varchar(20) DEFAULT NULL COMMENT ‘學號’,`name` varchar(32) DEFAULT NULL,PRIMARY KEY (`id`),KEY `gid` (`gid`),KEY `name` (`name`)) ENGINE=MyISAM DEFAULT CHARSET=utf8;導入後數據庫結果如下:php源碼如下:複製代碼 代碼如下: ?php header(“Content-Type:text/html;charset=utf-8”); require_once ‘excel_reader2.php’; set_time_limit(20000); ini_set(“memory_limit”,”2000M”); //使用pdo連接數據庫 $dsn = “mysql:host=localhost;dbname=alumni;”; $user = “root”; $password = “”; try{ $dbh = new PDO($dsn,$user,$password); $dbh-query(‘set names utf8;’); }catch(PDOException $e){ echo “連接失敗”.$e-getMessage(); } //pdo綁定參數操作 $stmt = $dbh-prepare(“insert into alumni(gid,student_no,name) values (:gid,:student_no,:name) “); $stmt-bindParam(“:gid”, $gid,PDO::PARAM_STR); $stmt-bindParam(“:student_no”, $student_no,PDO::PARAM_STR); $stmt-bindParam(“:name”, $name,PDO::PARAM_STR); //使用php-excel-reader讀取excel內容 $data = new Spreadsheet_Excel_Reader(); $data-setOutputEncoding(‘UTF-8’); $data-read(“stu.xls”); for ($i = 1; $i = $data-sheets[0][‘numRows’]; $i++) { for ($j = 1; $j = 3; $j++) { $student_no = $data-sheets[0][‘cells’][$i][1]; $name = $data-sheets[0][‘cells’][$i][2]; $gid = $data-sheets[0][‘cells’][$i][3]; } //將獲取的excel內容插入到數據庫 $stmt-execute(); } echo “執行成功”; echo “最後插入的ID:”.$dbh-lastInsertId(); ? 考慮到excel的量比較大,使用了PDO的綁定操作!

如何讀取excel文件 php

主要有兩個選擇,第一個是PHPExcelReader,另外一個是PHPExcel。

PHPExcelReader比較輕量級,僅支持Excel的讀取,實際上就是一個Reader。但是可惜的是不能夠支持Excel 2007的格式(.xlsx)。

PHPExcel比較強大,能夠將內存中的數據輸出成Excel文件,同時還能夠對Excel做各種操作,下面主要介紹下如何使用PHPExcel進行Excel 2007格式(.xlsx)文件的讀取。

下載PHPExcel後保存到自己的類文件目錄中,然後使用以下代碼可以打開Excel 2007(xlsx)格式的文件:

require_once ‘/libs/PHPExcel-1.8.0/Classes/PHPExcel.php’;     //修改為自己的目錄

echo ‘pTEST PHPExcel 1.8.0: read xlsx file/p’;

$objReader = PHPExcel_IOFactory::createReaderForFile($filename); 

$objPHPExcel = $objReader-load($filename);

$objPHPExcel-setActiveSheetIndex(1);

$date = $objPHPExcel-getActiveSheet()-getCell(‘A16’)-getValue();

輸出$date變量就能夠看到文件中的內容了。PHPExcel使用PHPExcel_IOFactory這個類來自動匹配所上傳的文件類型,當然我們也可以自己制定要解析的文件類型。之後通過load方法,將PHP文件加載到objPHPExcel對象中。如果Excel文件有多個Sheet,可以通過setActiveSheetIndex來設置當前活動的Sheet。

需要注意的是,對於Excel中的日期格式,PHPExcel讀出來的是不是日期類型,需要我們使用以下方法來進行日期類型轉換。

 echo date(“Y-m-d H:i:s”,PHPExcel_Shared_Date::ExcelToPHP($date));

下面的代碼顯示了如何遍歷顯示Excel的內容:

table id=”table_id”

?php

     $objWorksheet = $objPHPExcel-getActiveSheet();

     $i = 0;

     foreach($objWorksheet-getRowIterator() as $row){

     ?

          tr

          ?php

               $cellIterator = $row-getCellIterator();

               $cellIterator-setIterateOnlyExistingCells(false);

                    if( $i == 0 ){

                         echo ‘thead’;

                    }

               foreach($cellIterator as $cell){

                    echo ‘td’ . $cell-getValue() . ‘/td’;

               }

                    if( $i == 0 ){

                         echo ‘/thead’;

                    }

               $i++;

          ?

          /tr

     ?php

     }

?

/table

php讀取excel文件示例分享(更新修改excel)

複製代碼

代碼如下:

//模板存放目錄

$dir

=

$DOCUMENT_ROOT.’/backoffice/admin/oemcheck/’;

$templateName

=

‘1.xlsx’;

$outputFileName

=

‘模板.xlsx’;

$txt=’test’;

//實例化Excel讀取類

$PHPReader

=

new

PHPExcel_Reader_Excel2007();

if(!$PHPReader-canRead($dir.$templateName)){

$PHPReader

=

new

PHPExcel_Reader_Excel5();

if(!$PHPReader-canRead($dir.$templateName)){

echo

‘無法識別的Excel文件!’;

return

false;

}

}

//讀取Excel

$PHPExcel

=

$PHPReader-load($dir.$templateName);

//讀取工作表1

$currentSheet

=

$PHPExcel-getSheet(0);

$currentSheet-setCellValue(‘B13’,iconv(‘gbk’,’utf-8′,$txt));//表頭賦值//

//實例化Excel寫入類

$PHPWriter

=

new

PHPExcel_Writer_Excel2007($PHPExcel);

ob_start();

header(“Content-Type:

application/force-download”);

header(“Content-Type:

application/octet-stream”);

header(“Content-Type:

application/download”);

header(‘Content-Disposition:attachment;filename=”‘

.$outputFileName.

‘”‘);//輸出模板名稱

header(“Content-Transfer-Encoding:

binary”);

header(“Last-Modified:”.gmdate(“D,

d

M

Y

H:i:s”).”

GMT”);

header(‘Pragma:

public’);

header(‘Expires:

30′);

header(‘Cache-Control:

public’);

$PHPWriter-save(‘php://output’);

PHP遠程讀取excel文件,怎麼讀取

先用file_get_contents

或者curl把文件取回來

用phpexcel打開即可

php怎麼讀取excel 文件數據並輸出

PHPExcel

PHPExcel 是用來操作Office Excel 文檔的一個PHP類庫,它基於微軟的OpenXML標準和PHP語言。可以使用它來讀取、寫入不同格式的電子表格,如 Excel (BIFF) .xls, Excel 2007 (OfficeOpenXML) .xlsx, CSV, Libre/OpenOffice Calc .ods, Gnumeric, PDF, HTML等等。

PHP讀取示例代碼

//獲取上傳的excel臨時文件

$path = $_FILES[“file”][“tmp_name”];

//將臨時文件移動當前目錄,可自定義存儲位置

 

move_uploaded_file($_FILES[“file”][“tmp_name”],$_FILES[“file”][“name”]);

//將獲取在服務器中的Excel文件,此處為上傳文件名

$path = $_FILES[“file”][“name”];

//調用readExcel函數返回一個

二維數組

$exceArray = readExcel($path);

 

//創建一個讀取

excel函數

function readExcel($path){

        //引入PHPExcel類庫

    include ‘Classes/PHPExcel.php’;            

    include ‘Classes/PHPExcel/IOFactory.php’;

 

    $type = ‘Excel5’;//設置為Excel5代表支持2003或以下版本,

Excel2007代表2007版

    $xlsReader = \PHPExcel_IOFactory::createReader($type);  

    $xlsReader-setReadDataOnly(true);

    $xlsReader-setLoadSheetsOnly(true);

    $Sheets = $xlsReader-load($path);

    //開始讀取上傳到服務器中的Excel文件,返回一個

二維數組

    $dataArray = $Sheets-getSheet(0)-

toArray();

    return $dataArray;

}

原創文章,作者:FNGK,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/139788.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
FNGK的頭像FNGK
上一篇 2024-10-04 00:22
下一篇 2024-10-04 00:22

相關推薦

發表回復

登錄後才能評論