PHP將Excel導(dǎo)入數(shù)據(jù)庫及數(shù)據(jù)庫數(shù)據(jù)導(dǎo)出至Excel的方法
本文實(shí)例講述了PHP將Excel導(dǎo)入數(shù)據(jù)庫及數(shù)據(jù)庫數(shù)據(jù)導(dǎo)出至Excel的方法。分享給大家供大家參考。具體實(shí)現(xiàn)方法如下:
一.導(dǎo)入
導(dǎo)入需要使用能讀取Excel的組件,網(wǎng)上也有比較好的組件,這里分享我使用的:下載 提取碼:vxyn。(注意兩個(gè)文件有引用關(guān)系)
<?php
//傳入要導(dǎo)入的Excel的文件名
function import_to_DB($filename) {
require_once'reader.php';
$data = new Spreadsheet_Excel_Reader();
//創(chuàng)建讀取Excel的對象
$data->setOutputEncoding('utf-8');
//設(shè)置讀取Excel內(nèi)容后輸出的字符編碼
$data->read("data/Excel/{$filename}.xls");
$db = mysql_connect('localhost', '用戶名', '密碼') or die("Could not connect to database.");
//連接數(shù)據(jù)庫
mysql_query("set names 'uft8'");
//輸出中文
mysql_select_db('數(shù)據(jù)庫名');
//選擇數(shù)據(jù)庫
error_reporting(E_ALL ^ E_NOTICE);
for ($i = 1; $i <= $data->sheets[0]['numRows']; $i++) {
echo $data->sheets[0]['cells'][$i][列數(shù)];
//這里可以把每一行相應(yīng)列的值插到數(shù)據(jù)庫中,如:
/*
$sql="insert "表名" values(對應(yīng)項(xiàng)...)";
mysql_query($sql);
可加上錯(cuò)誤判斷
*/
}
?>
總之,能夠讀出表格中每一行中的相應(yīng)列$data->sheets[0][行][列]的值,插入操作就好辦了。
二.導(dǎo)出
導(dǎo)出可以利用MIME協(xié)議輕松導(dǎo)出表格文件,不用依賴任何組件。按如下格式設(shè)置header即可導(dǎo)出Excel,同時(shí)瀏覽器進(jìn)行下載
header('Content-type: text/html; charset=utf-8');
header("Content-type:application/vnd.ms-excel;charset=UTF-8"); //application/vnd.ms-excel指定輸出Excel格式
header("Content-Disposition:filename=表格文件名.xls");
//輸出的表格名稱
完整代碼如下:
<?php
header('Content-type: text/html; charset=utf-8');
header("Content-type:application/vnd.ms-excel;charset=UTF-8");
header("Content-Disposition:filename=表格文件名.xls");
$conn = mysql_connect("localhost","root","數(shù)據(jù)庫密碼") or die("不能連接數(shù)據(jù)庫");
mysql_select_db("數(shù)據(jù)庫名", $conn);
mysql_query("set names 'UTF-8'");
$sql="select * from 表名 where 條件";
$result=mysql_query($sql);
echo "表頭1\t表頭2\t表頭3\n";
while($row=mysql_fetch_array($result)){
echo $row[0]."\t".$row[1]."\t".$row[2]."\n";
}
?>
這里其實(shí)\t就是換格,\n就是換行。在一個(gè)網(wǎng)頁中設(shè)置這個(gè)php文件的鏈接,當(dāng)點(diǎn)擊時(shí)瀏覽器會(huì)自動(dòng)把傳過來的流保存為Excel文件。
希望本文所述對大家的php程序設(shè)計(jì)有所幫助。
- 利用phpExcel實(shí)現(xiàn)Excel數(shù)據(jù)的導(dǎo)入導(dǎo)出(全步驟詳細(xì)解析)
- php導(dǎo)入導(dǎo)出excel實(shí)例
- php中導(dǎo)出數(shù)據(jù)到excel時(shí)數(shù)字變?yōu)榭茖W(xué)計(jì)數(shù)的解決方法
- php將數(shù)據(jù)庫導(dǎo)出成excel的方法
- 使用PHPExcel實(shí)現(xiàn)數(shù)據(jù)批量導(dǎo)出為excel表格的方法(必看)
- php把數(shù)據(jù)表導(dǎo)出為Excel表的最簡單、最快的方法(不用插件)
- PHP實(shí)現(xiàn)導(dǎo)出帶樣式的Excel
- php導(dǎo)出excel格式數(shù)據(jù)問題
- php導(dǎo)出word文檔與excel電子表格的簡單示例代碼
- php原生導(dǎo)出excel文件的兩種方法(推薦)
- php中通用的excel導(dǎo)出方法實(shí)例
- php 自定義函數(shù)實(shí)現(xiàn)將數(shù)據(jù) 以excel 表格形式導(dǎo)出示例
相關(guān)文章
通過緩存數(shù)據(jù)庫結(jié)果提高PHP性能的原理介紹
眾所周知,緩存數(shù)據(jù)庫查詢的結(jié)果可以顯著縮短腳本執(zhí)行時(shí)間,并最大限度地減少數(shù)據(jù)庫服務(wù)器上的負(fù)載。如果要處理的數(shù)據(jù)基本上是靜態(tài)的,則該技術(shù)將非常有效。這是因?yàn)閷h(yuǎn)程數(shù)據(jù)庫的許多數(shù)據(jù)請求最終可以從本地緩存得到滿足,從而不必連接到數(shù)據(jù)庫、執(zhí)行查詢以及獲取結(jié)果2012-09-09
PHP中的自動(dòng)加載操作實(shí)現(xiàn)方法詳解
這篇文章主要介紹了PHP中的自動(dòng)加載操作實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了php自動(dòng)加載的概念、原理、實(shí)現(xiàn)方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2019-08-08
PHP中filter函數(shù)校驗(yàn)數(shù)據(jù)的方法詳解
這篇文章主要是介紹PHP中filter函數(shù)校驗(yàn)數(shù)據(jù)的方法詳解,PHP過濾器包含兩種類型:Validation用來驗(yàn)證驗(yàn)證項(xiàng)是否合法 、Sanitization用來格式化被驗(yàn)證的項(xiàng)目,因此它可能會(huì)修改驗(yàn)證項(xiàng)的值,將不合法的字符刪除,需要的朋友可以參考下2015-07-07
PHP實(shí)現(xiàn)微信公眾號(hào)企業(yè)號(hào)自定義菜單接口示例
這篇文章主要介紹了PHP實(shí)現(xiàn)微信公眾號(hào)企業(yè)號(hào)自定義菜單接口,結(jié)合實(shí)例形式分析了php自定義微信菜單類及微信接口相關(guān)操作技巧,需要的朋友可以參考下2017-08-08
PHP 計(jì)算代碼執(zhí)行耗時(shí)的代碼修正網(wǎng)上普遍錯(cuò)誤
前幾天測試 SQLite 插入大數(shù)據(jù)量的時(shí)候, 找了一些關(guān)于計(jì)算執(zhí)行時(shí)間的代碼, 發(fā)現(xiàn)網(wǎng)上普遍流傳著這樣一份代碼2011-05-05
php結(jié)合安卓客戶端實(shí)現(xiàn)查詢交互實(shí)例
本文給大家分享的是php結(jié)合安卓客戶端實(shí)現(xiàn)查詢交互實(shí)例,java端主要分三步來實(shí)現(xiàn):首先進(jìn)行 http request.網(wǎng)絡(luò)請求相關(guān)操作,第二步,使用execute方法發(fā)送HTTP GET請求,并返回HttpResponse對象,第三步,使用getEntity方法活得返回結(jié)果。有需要的小伙伴參考下2015-05-05
學(xué)習(xí)php設(shè)計(jì)模式 php實(shí)現(xiàn)單例模式(singleton)
這篇文章主要介紹了php設(shè)計(jì)模式中的單例模式,使用php實(shí)現(xiàn)單例模式,感興趣的小伙伴們可以參考一下2015-12-12

