我想從PHP導出數據& MySql。對於有大量數據(大約1000個字符)的字段,我將獲得空值。除了那些領域一切工作正常。 這是我現在使用的代碼。請檢查一次,如果有任何修改,請告訴我。我在谷歌搜索,所以很多人說它的緩存/內存問題。導出到ExCel顯示一些列爲空
<?php
function xlsBOF() {
echo pack("ssssss", 0x809, 0x8, 0x0, 0x10, 0x0, 0x0);
return;
}
function xlsEOF() {
echo pack("ss", 0x0A, 0x00);
return;
}
function xlsWriteNumber($Row, $Col, $Value) {
echo pack("sssss", 0x203, 14, $Row, $Col, 0x0);
echo pack("d", $Value);
return;
}
function xlsWriteLabel($Row, $Col, $Value) {
$L = strlen($Value);
echo pack("ssssss", 0x204, 8 + $L, $Row, $Col, 0x0, $L);
echo $Value;
return;
}
$sel_sql=mysql_query("select desc from table");
$myFile = date("m-d-Y").'_users.xls';
header("Pragma: public");
header("Expires: 0");
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Content-Type: application/force-download");
header("Content-Type: application/octet-stream");
header("Content-type: application/vnd.ms-excel");
header("Content-Type: application/download");;
header("Content-Disposition: attachment;filename=".$myFile);
header("Content-Transfer-Encoding: binary ");
// XLS Data Cell
xlsBOF();
xlsWriteLabel(0,1,"desc");
$xlsRow = 1;
while(list($desc)=mysql_fetch_row($sel_sql)) {
xlsWriteLabel($xlsRow,1,"$desc");
$xlsRow++;
}
xlsEOF();
?>
不,這些是您設置的標題;你怎麼實際輸出數據?作爲csv文件,html標記,以及實際的BIFF或OfficeOpenXML格式文件? –
@MarkBaker,我正在使用users.xls。即xls甲酸鹽。 – Kishore
請注意,只有一個內容類型標題將被髮送,您的列表中的最後一個四個;所以你可以消除三個冗餘的代碼行 –