php表格excel-九游会j9娱乐平台
『壹』 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函數
functionreadexcel($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;
}
『貳』 基於php中使用excel的簡單介紹
在工作中需要處理多語言的翻譯問題,翻譯都是寫在excel表格裡面。為了處理方便我就保留中文和英文兩列。
這樣需要將這些數據從excel中取出來,然乎保存在excel的數組中,通過使用循環數組將相應的數據放入到資料庫中。
所以工作的第一步就是要將數據從excel中取出來。這里我使用到了一個開源php處理excel類:phpexcel.
該項目的詳細信息
http://phpexcel.codeplex.com/
。
我目前使用的是phpexcel1.7.3版本,
解壓縮後裡面有一個phpexcel和phpexcel.php文件。
我們主要使用那個php文件。見下圖文件目錄結構
這個版本據說是可以支持excel2007,但是我使用2007編輯的xlsx是無法獲得該庫的支持。於是乎我就將它轉化為2003。感覺支持地很好。
下面介紹一下具體的使用:
復制代碼
代碼如下:
require_once('./phpexcel1.7.3/phpexcel.php');
$php_excel_obj
=
new
phpexcel();
$php_reader
=
newphpexcel_reader_excel2007();
if(!$php_reader->canread($file_name)){
$php_reader=
new
phpexcel_reader_excel5();
if(!$php_reader->canread($file_name)){
echo'no
excel!'
}
}
$php_excel_obj
=
$php_reader->load($file_name);
$current_sheet
=$php_excel_obj->getsheet(0);
上面的主要功能是初始化相關的excel類,並裝載excel第一個sheet
復制代碼
代碼如下:
$all_column
=$current_sheet->gethighestcolumn();
$all_row
=$current_sheet->gethighestrow();
以上分別獲得該表格的最大列值(字母表示如:『g'),和最大的行數(數值表示)
下面將使用循環來講excel裡面的數據讀到excel中:
復制代碼
代碼如下:
$all_arr
=
array();
$c_arr
=
array();
//字元對照表
for($r_i
=
1;
$r_i<=$all_row;
$r_i ){
$c_arr=
array();
for($c_i=
'a'
$c_i<=
'b'
$c_i ){
$adr=
$c_i
.
$r_i;
$value=
$current_sheet->getcell($adr)->getvalue();
if($c_i==
'a'
&&
empty($value)
)
break;
if(is_object($value))
$value=
$value->__tostring();
$c_arr[$c_i]=
$value;
}
$c_arr&&
$all_arr[]
=
$c_arr;
}
下面簡單地介紹一下phpexcel的寫操作,這個操作經常用於將資料庫中的數據導入到excel中,便於展示和做成更美觀的效果。
復制代碼
代碼如下:
require_once('./phpexcel1.7.3/phpexcel.php');
$excel_obj
=
new
phpexcel();
$objwriter
=
newphpexcel_writer_excel5($excel_obj);
$excel_obj->setactivesheetindex(0);
$act_sheet_obj=$excel_obj->getactivesheet();
$act_sheet_obj->settitle('sheet');
$act_sheet_obj->setcellvalue('a1',
'字元串內容');
$act_sheet_obj->setcellvalue('a2',
26);
$file_name
=
"output.xls";
$objwriter->save($file_name);
代碼很簡單,
首先初始化相關的excel寫類,然後寫入數據,最後保存為xls文件。
輸出的效果見圖
『叄』 php如何給excel表格添加水印
1
首先打開excel界面,進入excel工作區
步驟閱讀
『肆』 php怎樣讀取excel表格內容
常用的用php讀取excel的方法有以下三種,各自有各自的優缺點。個人推薦用第三種方法,因為它可以跨平台使用。x0dx0ax0dx0a1. 以.csv格式讀取x0dx0ax0dx0a將.xls轉換成.csv的文本格式,然後再用php分析這個文件,和php分析文本沒有什麼區別。x0dx0ax0dx0a優點:跨平台,效率比較高、可以讀寫。x0dx0ax0dx0a缺點:只能直接使用.csv的文件,如果經常接受.xls二進制文件的話需要手工轉換,不能自動化。一個文件只有一個sheet。x0dx0ax0dx0aphp有自帶的分析.csv函數:fgetcsvx0dx0ax0dx0aarray fgetcsv ( int $handle [, int $length [, string $delimiter [, string $enclosure]]] )x0dx0ax0dx0ahandle 一個由 fopen()、popen() 或 fsockopen() 產生的有效文件指針。x0dx0ax0dx0alength (可選)必須大於 cvs 文件內最長的一行。在 php 5 中該參數是可選的。如果忽略(在 php 5.0.4 以後的版本中設為 0)該參數的話,那麼長度就沒有限制,不過可能會影響執行效率。x0dx0ax0dx0adelimiter (可選)設置欄位分界符(只允許一個字元),默認值為逗號。x0dx0ax0dx0aenclosure (可選)設置欄位環繞符(只允許一個字元),默認值為雙引號。該參數是在 php 4.3.0 中添加的。 和 fgets() 類似,只除了 fgetcsv() 解析讀入的行並找出 csv 格式的欄位然後返回一個包含這些欄位的數組。x0dx0ax0dx0afgetcsv() 出錯時返回 false,包括碰到文件結束時。x0dx0ax0dx0a注意: csv 文件中的空行將被返回為一個包含有單個 null 欄位的數組,不會被當成錯誤。x0dx0ax0dx0a當然也可以自己手動分析字元串。x0dx0ax0dx0a還可以利用fputcsv函數將行格式化為 csv 並寫入文件指針。x0dx0ax0dx0a2. odbc鏈接數據源x0dx0ax0dx0a優點:支持多種格式,cvs, xls等。支持讀寫,使用標准sql語言,和sqlserver、mysql資料庫幾乎完全一樣。x0dx0ax0dx0a缺點:值支持windows伺服器x0dx0ax0dx0a3. php自定義類x0dx0ax0dx0a優點:跨平台。某些類支持寫操作。支持.xls二進制文件x0dx0ax0dx0a常用的類有phpexcelreader、phpexcel。其中後者支持讀寫,但是需要php5.2以上版本。x0dx0ax0dx0aphpexcelreader是專門用來讀取文件的。返回一個數組,包含表格的所有內容。x0dx0ax0dx0a該 class 使用的方法可以參考網站下載回來的壓縮檔中的 example.php。x0dx0ax0dx0a不過我下載回來的 (版本 2009-03-30),有兩點要注意:x0dx0ax0dx0areader.php 中的下面這行要修改x0dx0ax0dx0a將 require_once 『spreadsheet/excel/reader/oleread.php』;x0dx0ax0dx0a改為 require_once 『oleread.inc』;x0dx0ax0dx0aexample.php 中x0dx0ax0dx0a修改 $data->setoutputencoding(』cp1251′);x0dx0ax0dx0a為 $data->setoutputencoding(』cp936′);x0dx0ax0dx0aexample2.php 中x0dx0ax0dx0a修改 nl2br(htmlentities($data->sheets[$sheet]['cells'][$row][$col]));x0dx0ax0dx0a為 $table_output[$sheet] .= nl2br(htmlspecialchars($data->sheets[$sheet]['cells'][$row][$col]));x0dx0ax0dx0a不然中文會有問題。x0dx0ax0dx0a繁體的話可以修改為cp950、日文是cp932,具體可參考codepage說明。x0dx0ax0dx0a修改 $data->read(』jxlrwtest.xls』) 為自己的 excel 文件名,zip 檔中附的 jxlrwtest.xls 應該是壞了。
『伍』 php怎麼導出大量數據的excel
php導出大量數據excel的具體操作步驟如下:
1、使用phpstudy搭建一個測試平台,直接訪問資料庫。