エクスポートの原則は、実際には、ヘッダー ヘッダーを設定して、ブラウザーに Excel 形式を使用して解析および読み取りを行い、生成するように指示することです。コンテンツを出力する HTML テーブル。セルの結合は、実際には HTML テーブルの結合と同じであり、スタイル属性とフィールドをサポートし、td
スタイルを操作してセルを制御することもできます。
エクスポートされた疑似コードは次のとおりです:
/** * 导出excel文件 * * @param string $excelFileName 导出的文件名 * @param array $title excel的标题列 * @param array $data 导出的数据 */ public function exportExcel($excelFileName, $title, $data) { $str = "<html xmlns:o=\"urn:schemas-microsoft-com:office:office\"\r\nxmlns:x=\"urn:schemas-microsoft-com:office:excel\"\r\nxmlns=\"http://www.w3.org/TR/REC-html40\">\r\n<head>\r\n<meta http-equiv=Content-Type content=\"text/html; charset=utf-8\">\r\n</head>\r\n<body>"; $str .="<table border=1 align=center cellpadding=0 cellspacing=0>"; // 拼接标题行 $str .= '<tr style="height:25px;font-size:13px;font-weight: bold;">'; foreach ($title as $key => $val) { $str .= '<td>'.$val.'</td>'; } $str .= '</tr>'; // 拼接数据 foreach ($data as $key => $val) { $str .= '<tr style="text-align: left;height:25px;font-size:13px;">'; foreach ($val as $v) { if (is_numeric($v) && $v > 100000000) { $str .= "<td style='vnd.ms-excel.numberformat:@'>".$v."</td>"; } elseif (is_numeric($v) && preg_match('/^[0-9]+(\.[0-9]{2})+$/', $v)) { // 是两位小数的保留2位显示 $str .= "<td style='vnd.ms-excel.numberformat:0.00'>".$v."</td>"; } elseif (preg_match('/^[0-9]{4}-(0[1-9]|1[0-2])-(0[1-9]|[1-2][0-9]|3[0-1]) (0[0-9]|1[0-9]|2[0-4]):(0[0-9]|[1-5][0-9]):(0[0-9]|[1-5][0-9])$/', $v)) { // 是日期 $str .= "<td style='vnd.ms-excel.numberformat:yyyy-mm-dd\ hh\:mm\:ss'>".$v."</td>"; } else { $str .= "<td>".$v."</td>"; } } $str .= "</tr>\n"; } $str .= "</table></body></html>"; // 实现文件下载 header("Content-Type: application/vnd.ms-excel; name='excel'"); header("Content-type: application/octet-stream"); header("Content-Disposition: attachment; filename=" . $excelFileName); header("Cache-Control: must-revalidate, post-check=0, pre-check=0"); header("Pragma: no-cache"); header("Expires: 0"); exit($str); }
いくつかのスタイルといくつかの定期的なチェックを作成しただけですが、不要な場合は削除できます。主に、いくつかのセルの書式設定命令について説明します。
上記のエクスポートには、いくつかの一般的な問題があります:
1. ID 番号、携帯電話番号、その他の大きな数値の場合、科学的表記法を使用して表示されます。文字列表示を気にしない場合は、 td
style='vnd.ms-excel.numberformat:@'
のスタイルを設定することで制御できます。これは、テキストで表示することを意味します。 format
2.数値の場合、小数点以下の桁数を保持する必要がある場合は、 style='vnd.ms-excel.numberformat:0.00'
を設定できます。小数点以下の桁数を保持する必要がある場合は、 , いくつかの 0 を書き込むだけです。渡された値の小数点以下の桁数が保持できる数よりも多い場合、値は四捨五入されることに注意してください。たとえば、入力が 87.98 で、小数点以下の桁数の設定が vnd.ms-excel.numberformat:0.0
の場合、88.0
3 と表示されます。 style= 'vnd.ms-excel.numberformat:yyyy-mm-dd\ hh\:mm\:ss'
スペース、コロンなどはエスケープする必要があります。 HTML でスペース文字テーブルを使用している場合は少し異なりますが、上記は一般的に使用される形式の組み合わせであり、自分で変換を行うことができます。他にもいくつかの変換があります style='vnd.ms-excel.numberformat:\"Short Date\"'
これは 2019/7/1
; style として表示されます。 ='vnd.ms-excel.numberformat:\"Medium Date\"'
は 1-Jul-19
4 と表示されます。パーセンテージ表示。パーセントを表示するには、style='vnd.ms-excel.numberformat:0%'
という形式を使用できます。注意すべき点は、値が表示されるときに 100 倍に増幅されることです。つまり、2%
として表示したい場合、渡す値は 0.02
5 である必要があります。千の位の区切り文字です。桁区切り記号を使用して数値を表示する必要がある場合は、style='vnd.ms-excel.numberformat:#,
' と設定できます。たとえば、
123456 が表示されます。 as
123,456
上記は最も一般的に使用されるものです。ここにも一般的に使用されるリストがありますが、彼が使用するキーワードは
mso-number-format I
style## を試しました #mso-number-format
と vnd.ms-excel.numberformat
の両方を # で使用できます。
CSV ファイルは実際には汎用ファイルであり、テキスト ファイルとも呼ばれます。そのため、エクスポートした CSV データグラム ファイルではセル スタイルを設定できず、バイナリ ファイルである xls ファイルを Excel などのツールを使用して開く必要があります。これをより速くエクスポートするための厳密な要件がない場合、Alibaba Cloud 上の一部のエクスポートは CSV 形式であると思いますが、ここで必要なのは Excel ファイルである必要があります。
疑似コードは次のとおりです:
/** * 导出CSV标准文件 * * @param string $fileName 导出的文件名 * @param array $title 标题列 * @param array $data 导出的数据 */ function exportCsv($fileName, $title, $data) { // 清空输出流,防止有别的信息 ob_end_clean(); // 打开一个输出流 ob_start(); // 设置header信息 header("Content-Type: text/csv"); header("Content-Disposition:filename=". $fileName); // 打开文件流 $fileHandle = fopen('php://output', 'w'); //转码 防止乱码 fwrite($fileHandle, chr(0xEF).chr(0xBB).chr(0xBF)); // 先把标题写进去 fputcsv($fileHandle, $title); $index = 0; foreach ($data as $item) { // 每2000条释放一次资源 if ($index == 2000) { $index = 0; ob_flush(); flush(); } $index++; fputcsv($fileHandle, $item); } // 释放资源 ob_flush(); flush(); ob_end_clean(); }
推奨学習: 「PHP ビデオ チュートリアル 」
以上がPHP をネイティブに使用して Excel および CSV ファイルをエクスポートする方法について説明した記事の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。