基于PHP導(dǎo)出Excel的小經(jīng)驗(yàn) 完美解決亂碼問(wèn)題
更新時(shí)間:2013年06月10日 09:20:33 作者:
本篇文章是對(duì)PHP導(dǎo)出Excel亂碼問(wèn)題的解決方法就行了詳細(xì)的分析介紹,需要的朋友參考下
我在PHP項(xiàng)目里要求把數(shù)據(jù)導(dǎo)出為Excel,并且數(shù)據(jù)中包含中文.
網(wǎng)上大概了解一下可是使用PHPExcel,可是相對(duì)我的需求,這個(gè)框架太復(fù)雜了.于是還是想找找簡(jiǎn)單做法.
網(wǎng)上發(fā)現(xiàn)其實(shí)最簡(jiǎn)單可以這樣寫,但問(wèn)題是這種做法中文的編碼不可靠..
<?php
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:attachment;filename=export_data.xls");
echo "姓名"."\t";
echo "繁體"."\t";
echo "博客"."\t";
echo "\n";
echo "jason"."\t";
echo "@"."\t";
echo "javaeye"."\t";
?>
有些同學(xué)會(huì)想到header加入字符集
header("Content-type:application/vnd.ms-excel;charset=UTF-8");
問(wèn)題: 這里只是告訴瀏覽器要選什么字符集查看,最終我的需求還是要生成xls文件.
當(dāng)然.有些同學(xué)還會(huì)想到用iconv轉(zhuǎn)碼.
echo iconv("當(dāng)前編碼","GB18030","此博客來(lái)源于javaeye,by jason");
問(wèn)題: 這樣文件里的漢字編碼就GB18030,可是Excel這么知道用什么編碼打開呢?只能完全依賴OS默認(rèn).可是如果碰到繁體BIG5這么辦,還是會(huì)亂碼. 所以還是不靠譜.
最后我采用phpMyAdmin的做法.用HTMLExcel, HTML我們比較熟悉,格式如下.
<html xmlns:o="urn:schemas-microsoft-com:office:office"
xmlns:x="urn:schemas-microsoft-com:office:excel"
xmlns="http://www.w3.org/TR/REC-html40">
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<meta http-equiv="Content-type" content="text/html;charset=UTF-8" />
<style id="Classeur1_16681_Styles"></style>
</head>
<body>
<div id="Classeur1_16681" align=center x:publishsource="Excel">
<table x:str border=0 cellpadding=0 cellspacing=0 width=100% style="border-collapse: collapse">
<tr><td class=xl2216681 nowrap>1234</td><td class=xl2216681 nowrap>Robbin會(huì)吐口水</td></tr>
<tr><td class=xl2216681 nowrap>5678</td><td class=xl2216681 nowrap>javaeye網(wǎng)站</td></tr>
</table>
</div>
</body>
</html>
這下可以直接echo了,又不需要iconv轉(zhuǎn)碼,只要設(shè)置好HTML里的Content-type(這里用的是UTF-8),是不是有舒服的感覺(jué)呢? 當(dāng)然header還是要加上
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:attachment;filename=export_data.xls");
一點(diǎn)小經(jīng)驗(yàn)和各位同學(xué)分享一下..
網(wǎng)上大概了解一下可是使用PHPExcel,可是相對(duì)我的需求,這個(gè)框架太復(fù)雜了.于是還是想找找簡(jiǎn)單做法.
網(wǎng)上發(fā)現(xiàn)其實(shí)最簡(jiǎn)單可以這樣寫,但問(wèn)題是這種做法中文的編碼不可靠..
復(fù)制代碼 代碼如下:
<?php
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:attachment;filename=export_data.xls");
echo "姓名"."\t";
echo "繁體"."\t";
echo "博客"."\t";
echo "\n";
echo "jason"."\t";
echo "@"."\t";
echo "javaeye"."\t";
?>
有些同學(xué)會(huì)想到header加入字符集
復(fù)制代碼 代碼如下:
header("Content-type:application/vnd.ms-excel;charset=UTF-8");
問(wèn)題: 這里只是告訴瀏覽器要選什么字符集查看,最終我的需求還是要生成xls文件.
當(dāng)然.有些同學(xué)還會(huì)想到用iconv轉(zhuǎn)碼.
復(fù)制代碼 代碼如下:
echo iconv("當(dāng)前編碼","GB18030","此博客來(lái)源于javaeye,by jason");
問(wèn)題: 這樣文件里的漢字編碼就GB18030,可是Excel這么知道用什么編碼打開呢?只能完全依賴OS默認(rèn).可是如果碰到繁體BIG5這么辦,還是會(huì)亂碼. 所以還是不靠譜.
最后我采用phpMyAdmin的做法.用HTMLExcel, HTML我們比較熟悉,格式如下.
復(fù)制代碼 代碼如下:
<html xmlns:o="urn:schemas-microsoft-com:office:office"
xmlns:x="urn:schemas-microsoft-com:office:excel"
xmlns="http://www.w3.org/TR/REC-html40">
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<meta http-equiv="Content-type" content="text/html;charset=UTF-8" />
<style id="Classeur1_16681_Styles"></style>
</head>
<body>
<div id="Classeur1_16681" align=center x:publishsource="Excel">
<table x:str border=0 cellpadding=0 cellspacing=0 width=100% style="border-collapse: collapse">
<tr><td class=xl2216681 nowrap>1234</td><td class=xl2216681 nowrap>Robbin會(huì)吐口水</td></tr>
<tr><td class=xl2216681 nowrap>5678</td><td class=xl2216681 nowrap>javaeye網(wǎng)站</td></tr>
</table>
</div>
</body>
</html>
這下可以直接echo了,又不需要iconv轉(zhuǎn)碼,只要設(shè)置好HTML里的Content-type(這里用的是UTF-8),是不是有舒服的感覺(jué)呢? 當(dāng)然header還是要加上
復(fù)制代碼 代碼如下:
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:attachment;filename=export_data.xls");
一點(diǎn)小經(jīng)驗(yàn)和各位同學(xué)分享一下..
您可能感興趣的文章:
- 利用phpExcel實(shí)現(xiàn)Excel數(shù)據(jù)的導(dǎo)入導(dǎo)出(全步驟詳細(xì)解析)
- PHPExcel讀取Excel文件的實(shí)現(xiàn)代碼
- phpExcel中文幫助手冊(cè)之常用功能指南
- PHP導(dǎo)入Excel到MySQL的方法
- php讀取EXCEL文件 php excelreader讀取excel文件
- php導(dǎo)入導(dǎo)出excel實(shí)例
- ThinkPHP使用PHPExcel實(shí)現(xiàn)Excel數(shù)據(jù)導(dǎo)入導(dǎo)出完整實(shí)例
- php中使用PHPExcel讀寫excel(xls)文件的方法
- php生成excel文件的簡(jiǎn)單方法
- PHP中創(chuàng)建和編輯Excel表格的方法
相關(guān)文章
PHP面向?qū)ο蟪绦蛟O(shè)計(jì)子類擴(kuò)展父類(子類重新載入父類)操作詳解
這篇文章主要介紹了PHP面向?qū)ο蟪绦蛟O(shè)計(jì)子類擴(kuò)展父類(子類重新載入父類)操作,涉及php面向?qū)ο蠓椒ㄖ貙懪c擴(kuò)展相關(guān)操作技巧,需要的朋友可以參考下2019-06-06
學(xué)習(xí)php設(shè)計(jì)模式 php實(shí)現(xiàn)橋梁模式(bridge)
這篇文章主要介紹了php設(shè)計(jì)模式中的橋梁模式,使用php實(shí)現(xiàn)橋梁模式,感興趣的小伙伴們可以參考一下2015-12-12
PHP學(xué)習(xí)筆記(三):數(shù)據(jù)類型轉(zhuǎn)換與常量介紹
這篇文章主要介紹了PHP學(xué)習(xí)筆記(三):數(shù)據(jù)類型轉(zhuǎn)換與常量介紹,本文講解了PHP數(shù)據(jù)類型相互轉(zhuǎn)換、常量的聲明與使用等內(nèi)容,需要的朋友可以參考下2015-04-04
淺析php fwrite寫入txt文件的時(shí)候用 \r\n不能換行的問(wèn)題
以下是對(duì)php中fwrite寫入txt文件的時(shí)候用 \r\n不能換行的問(wèn)題進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下2013-08-08
PHP laravel使用自定義郵件類實(shí)現(xiàn)發(fā)送郵件
這篇文章主要為大家詳細(xì)介紹了PHP laravel如何通過(guò)自定義郵件類實(shí)現(xiàn)發(fā)送郵件功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以嘗試一下2022-10-10
php源碼分析之DZX1.5加密解密函數(shù)authcode用法
這篇文章主要介紹了php源碼分析之DZX1.5加密解密函數(shù)authcode用法,實(shí)例分析了DZX1.5中authcode函數(shù)加密與解密的使用技巧,需要的朋友可以參考下2015-06-06

