Heim  >  Artikel  >  Backend-Entwicklung  >  PHP implementiert den Export stilisierter Excel-Instanzfreigaben

PHP implementiert den Export stilisierter Excel-Instanzfreigaben

墨辰丷
墨辰丷Original
2018-06-01 14:17:432226Durchsuche

Manchmal beschweren sich Kunden, dass das von der Software für sie exportierte Excel-Format zu hässlich ist. Vielleicht hilft Ihnen dieser Artikel. Beim Exportieren von Daten mit PHP können Sie auch Farbe, Schriftgröße, Fettschrift, Zellen zusammenführen usw. festlegen.

Wenn Sie bei der Arbeit exportieren, müssen Sie eine benutzerdefinierte Tabelle exportieren oder Sie haben das Gefühl, dass das exportierte Excel-Format zu hässlich ist.

Farbe, Schriftgröße, Fettdruck, Zellen verbinden usw. müssen festgelegt werden.

Rendering:


PHP-Code:

/**
* 导出文件
* @return string
*/
public function export()
{
$file_name  = "成绩单-".date("Y-m-d H:i:s",time());
$file_suffix = "xls";
header("Content-Type: application/vnd.ms-excel");
header("Content-Disposition: attachment; filename=$file_name.$file_suffix");
//根据业务,自己进行模板赋值。
$this->display();
}

HTML-Code:

<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">
<head>
<meta http-equiv=Content-Type content="text/html; charset=utf-8">
<meta name=ProgId content=Excel.Sheet>
<meta name=Generator content="Microsoft Excel 11">
</head>
<body>
<table border=1 cellpadding=0 cellspacing=0 width="100%" >
<tr>
<td colspan="5" align="center">
<h2>成绩单</h2>
</td>
</tr>
<tr>
<td style=&#39;width:54pt&#39; align="center">编号</td>
<td style=&#39;width:54pt&#39; align="center">姓名</td>
<td style=&#39;width:54pt&#39; align="center">语文</td>
<td style=&#39;width:54pt&#39; align="center">数学</td>
<td style=&#39;width:54pt&#39; align="center">英语</td>
</tr>
<tr>
<td align="center">1</td>
<td style="background-color: #00CC00;" align="center">Jone</td>
<td style="background-color: #00adee;" align="center">90</td>
<td style="background-color: #00CC00;" align="center">85</td>
<td style="background-color: #00adee;" align="center">100</td>
</tr>
<tr>
<td align="center">2</td>
<td style="background-color: #00CC00;" align="center">Tom</td>
<td style="background-color: #00adee;" align="center">99</td>
<td style="background-color: #00CC00;" align="center">85</td>
<td style="background-color: #00adee;" align="center">80</td>
</tr>
</table>
</body>
</html>

Sehen wir uns eine praktischere Komponente an

Hier müssen wir zwei Softwarepakete von PEAR verwenden, Spreadsheet Excel Writer und OLE. Wenn nicht, können Sie sie von http herunterladen : Laden Sie //pear.php.net/package/Spreadsheet_Excel_Writer/ und http://pear.php.net/package/OLE/ herunter, entpacken Sie sie und legen Sie sie im PEAR-Verzeichnis ab.

Der gesamte Code lautet wie folgt:

<?php
include &#39;Writer.php&#39;;

/* *** 准备导出的数据 *** */
$head = &#39;One Week Schedule&#39;;
$data = array(&#39;Monday&#39; =>   array( array(&#39;time&#39; => &#39;09:00&#39;, &#39;event&#39; => &#39;公司例会例会&#39;),
                      array(&#39;time&#39; => &#39;14:00&#39;, &#39;event&#39; => &#39;部门例会&#39;)
                    ),
         &#39;Tuesday&#39; =>   array( array(&#39;time&#39; => &#39;09:30&#39;, &#39;event&#39; => &#39;和 Mr. Stinsen 早餐&#39;)),
         &#39;Wednesday&#39; =>   array(array(&#39;time&#39; => &#39;12:10&#39;, &#39;event&#39; => &#39;市场中阶报告&#39;),
                    array(&#39;time&#39; => &#39;15:30&#39;, &#39;event&#39; => &#39;市场部战略部署会议&#39;) ),
         &#39;Thursday&#39; =>   array( array(&#39;time&#39; => &#39;&#39;, &#39;event&#39; => &#39;&#39;)),
         &#39;Friday&#39; =>   array( array(&#39;time&#39; => &#39;16:00&#39;, &#39;event&#39; => &#39;WoC Stock 研讨会&#39;),
                    array(&#39;time&#39; => &#39;17:00&#39;, &#39;event&#39; => &#39;飞往华尔街&#39;),
                    array(&#39;time&#39; => &#39;21:00&#39;, &#39;event&#39; => &#39;会见克林顿&#39;))
     );
/* *** *** */

$workbook = new Spreadsheet_Excel_Writer();
$filename = date(&#39;YmdHis&#39;).&#39;.xls&#39;;//csv
$workbook->send($filename); // 发送 Excel 文件名供下载
$workbook->setVersion( 8 );

$sheet = &$workbook->addWorksheet("Sheet1");   // 创建工作表
$sheet->setInputEncoding(&#39;utf-8&#39;);          // 字符集
$headFormat = &$workbook->addFormat(array(&#39;Size&#39; => 14, &#39;Align&#39; => &#39;center&#39;,&#39;Color&#39; => &#39;white&#39;, &#39;FgColor&#39; => &#39;brown&#39;, &#39;Bold&#39;=>&#39;1&#39;, &#39;Border&#39; => &#39;1&#39;));//定义格式
$dayFormat = &$workbook->addFormat(array(&#39;Size&#39; => 12, &#39;Align&#39; => &#39;center&#39;, &#39;VAlign&#39; => &#39;vcenter&#39;, &#39;FgColor&#39; => &#39;green&#39;, &#39;Color&#39; => &#39;white&#39;, &#39;Border&#39; => &#39;1&#39;));//定义格式
$dataFormat = &$workbook->addFormat(array(&#39;Size&#39; => 10, &#39;Align&#39; => &#39;left&#39;, &#39;Border&#39; => &#39;1&#39;, &#39;Color&#39; => &#39;black&#39;, &#39;FgColor&#39;=> &#39;cyan&#39;));//定义格式

$sheet->setColumn(0, 0, 20);   // 设置宽度
$sheet->setColumn(1, 1, 15);   // 设置宽度
$sheet->setColumn(2, 2, 30);   // 设置宽度

$r = 0;   
$sheet->write(0, $r, $head, $headFormat);   // 表格标题
$sheet->mergeCells(0, 0, 0, 2);   // 跨列显示

$r++;   // 数据从第2行开始
foreach ($data as $day => $events){
   $c = 0;
   $sheet->write($r, $c, $day, $dayFormat);
   if (!$events){
     // 当天没有计划
     $r++;
   } else {
     $startRow = $r;
     foreach ($events as $e){
        $c = 1;
        $sheet->write($r, $c++, $e[&#39;time&#39;], $dataFormat);   // 工作表写入数据
        $sheet->write($r, $c++, $e[&#39;event&#39;], $dataFormat);   // 工作表写入数据
        $r++;
     }
     // 合并 $day 单元格
     $sheet->mergeCells($startRow, 0, $r - 1, 0);
   }
}
$workbook->close(); // 完成下载
 ?>

Zusammenfassung: Das Obige ist der gesamte Inhalt dieses Artikels, ich hoffe, er wird hilfreich sein zum Lernen aller.

Verwandte Empfehlungen:

Detaillierte Erläuterung der Socket-Nutzung von PHP

php Strtotime-Funktionsleistungsanalyse_phpTipps

phpDie neueste Lösung für den Fehler Aufruf der undefinierten Funktion curl_init()

Das obige ist der detaillierte Inhalt vonPHP implementiert den Export stilisierter Excel-Instanzfreigaben. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn