PHP匯入匯出Excel檔案的方法_PHP教程

來源:互聯網
上載者:User
下面我來給大家介紹在php中操作excel兩個執行個體,一個是利用PHP-ExcelReader匯入excel並輸出,另一種是直接輸入excel並匯出,下面看執行個體。


藉助PHP-ExcelReader這個開源類,我們可以輕鬆地匯入Excel檔案資料,範例程式碼如下:

PHP-ExcelReader下載地址:http://sourceforge.net/projects/phpexcelreader/

例.匯入Excel檔案

代碼如下 複製代碼

require_once 'Excel/reader.php';
$data = new Spreadsheet_Excel_Reader();
$data->setOutputEncoding('gbk');
$data->read('test.xls');
for ($i = 1; $i <= $data->sheets[0]['numRows']; $i++) {
for ($j = 1; $j <= $data->sheets[0]['numCols']; $j++) {
echo """.$data->sheets[0]['cells'][$i][$j]."",";
}
echo "n";
}
?>

例.phpexcel導到excel

1. test.php

代碼如下 複製代碼

require_once 'reader.php';

// ExcelFile($filename, $encoding);
$data = new Spreadsheet_Excel_Reader();

// Set output Encoding.
$data->setOutputEncoding('gbk');

//”data.xls”是指要匯入到mysql中的excel檔案
$data->read('data.xls');

@ $db = mysql_connect('localhost', 'root', '123456') or
die("Could not connect to database.");//串連資料庫
mysql_query("set names 'gbk'");//輸出中文
mysql_select_db('mydb'); //選擇資料庫
error_reporting(E_ALL ^ E_NOTICE);

for ($i = 1; $i <= $data->sheets[0]['numRows']; $i++) {
//以下注釋的for迴圈列印excel表資料
/*
for ($j = 1; $j <= $data->sheets[0]['numCols']; $j++) {
echo """.$data->sheets[0]['cells'][$i][$j]."",";
}
echo "n";
//PHP開原始碼


*/
//以下代碼是將excel表資料【3個欄位】插入到mysql中,根據你的excel表欄位的多少,改寫以下代碼吧!
$sql = "INSERT INTO test VALUES('".
$data->sheets[0]['cells'][$i][1]."','".
$data->sheets[0]['cells'][$i][2]."','".
$data->sheets[0]['cells'][$i][3]."')";
echo $sql.'
';
$res = mysql_query($sql);
}

?>

例.匯出excel檔案


比如我需要一個做php匯出 excel的的程式,只需要把相關的資料匯出到excel表就可以了,這麼簡單的操作就不需要用那些類庫什麼的了。直接用header的方式就可以了:header("Content-type:application/vnd.ms-excel");

看看代碼:

代碼如下 複製代碼

header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:attachment;filename=Export_test.xls");
$tab="t"; $br="n";
$head="編號".$tab."備忘".$br;
//輸出內容如下:
echo $head.$br;
echo "test321318312".$tab;
echo "string1";
echo $br;

echo "330181199006061234".$tab; //直接輸出會被Excel識別為數字類型
echo "number";
echo $br;

echo "="330181199006061234"".$tab; //原樣輸出需要處理
echo "string2";
echo $br;
?>

在匯出後會發現一個問題,如果資料是數字會出現一些意想不到的情況。比如,"012345",在excel中會變成"12345";如果輸入社會安全號碼碼這樣的長數字,在excel中會用科學計數法表示出來,並且最後的四位元字會出現偏差,變位0000等情況。這就需要把儲存格設定為文字格式設定,方法是
echo "="330181199006061234""如果程式是utf-8編碼的,還需要用iconv函數去轉碼,不然是會亂碼的,亂碼的。

另word格式匯入類似,,指定header就可以了:

代碼如下 複製代碼

header("Content-Type: application/msword");
header("Content-Disposition: attachment; filename=doc.doc");

http://www.bkjia.com/PHPjc/633143.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/633143.htmlTechArticle下面我來給大家介紹在php中操作excel兩個執行個體,一個是利用PHP-ExcelReader匯入excel並輸出,另一種是直接輸入excel並匯出,下面看執行個體。 藉助...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.