Heim  >  Artikel  >  Backend-Entwicklung  >  PHP导出带样式的Excel文件的示例代码

PHP导出带样式的Excel文件的示例代码

WBOY
WBOYOriginal
2016-07-25 08:55:27992Durchsuche
  1. /**
  2. * 导出带有样式的excel
  3. * edit:bbs.it-home.org
  4. */
  5. include 'Writer.php';
  6. /* *** 准备导出的数据 *** */
  7. $head = 'One Week Schedule';
  8. $data = array('Monday' => array( array('time' => '09:00', 'event' => '公司例会例会'),
  9. array('time' => '14:00', 'event' => '部门例会')
  10. ),
  11. 'Tuesday' => array( array('time' => '09:30', 'event' => '和 Mr. Stinsen 早餐')),
  12. 'Wednesday' => array(array('time' => '12:10', 'event' => '市场中阶报告'),
  13. array('time' => '15:30', 'event' => '市场部战略部署会议') ),
  14. 'Thursday' => array( array('time' => '', 'event' => '')),
  15. 'Friday' => array( array('time' => '16:00', 'event' => 'WoC Stock 研讨会'),
  16. array('time' => '17:00', 'event' => '飞往华尔街'),
  17. array('time' => '21:00', 'event' => '会见克林顿'))
  18. );
  19. /* *** *** */
  20. $workbook = new Spreadsheet_Excel_Writer();
  21. $filename = date('YmdHis').'.xls';//csv
  22. $workbook->send($filename); // 发送 Excel 文件名供下载
  23. $workbook->setVersion( 8 );
  24. $sheet = &$workbook->addWorksheet("Sheet1"); // 创建工作表
  25. $sheet->setInputEncoding('utf-8'); // 字符集
  26. $headFormat = &$workbook->addFormat(array('Size' => 14, 'Align' => 'center','Color' => 'white', 'FgColor' => 'brown', 'Bold'=>'1', 'Border' => '1'));//定义格式
  27. $dayFormat = &$workbook->addFormat(array('Size' => 12, 'Align' => 'center', 'VAlign' => 'vcenter', 'FgColor' => 'green', 'Color' => 'white', 'Border' => '1'));//定义格式
  28. $dataFormat = &$workbook->addFormat(array('Size' => 10, 'Align' => 'left', 'Border' => '1', 'Color' => 'black', 'FgColor'=> 'cyan'));//定义格式
  29. $sheet->setColumn(0, 0, 20); // 设置宽度
  30. $sheet->setColumn(1, 1, 15); // 设置宽度
  31. $sheet->setColumn(2, 2, 30); // 设置宽度
  32. $r = 0;
  33. $sheet->write(0, $r, $head, $headFormat); // 表格标题
  34. $sheet->mergeCells(0, 0, 0, 2); // 跨列显示
  35. $r++; // 数据从第2行开始
  36. foreach ($data as $day => $events){
  37. $c = 0;
  38. $sheet->write($r, $c, $day, $dayFormat);
  39. if (!$events){
  40. // 当天没有计划
  41. $r++;
  42. } else {
  43. $startRow = $r;
  44. foreach ($events as $e){
  45. $c = 1;
  46. $sheet->write($r, $c++, $e['time'], $dataFormat); // 工作表写入数据
  47. $sheet->write($r, $c++, $e['event'], $dataFormat); // 工作表写入数据
  48. $r++;
  49. }
  50. // 合并 $day 单元格
  51. $sheet->mergeCells($startRow, 0, $r - 1, 0);
  52. }
  53. }
  54. $workbook->close(); // 完成下载
  55. ?>
复制代码

代码说明: $sheet = &$workbook->addWorksheet("Sheet1"); // 创建工作表,返回工作表的调用。可以在一个Excel工作簿中创建多个工作表。 $headFormat = &$workbook->addFormat($param); // 创建一个格式,有下面的可用格式,参考官方说明 http://pear.php.net/manual/en/package.fileformats.spreadsheet-excel-writer.spreadsheet-excel-writer-workbook.addformat.php Align

Bold

Bottom

Top

Left

Right

Border

BorderColor

BottomColor

TopColor

RightColor

LeftColor

FgColor

BgColor

Color

Pattern

Underline

TextRotation

Size

NumFormat

Script

$workbook->send($filename); // 发送HTTP Header,准备下载,$filename 下载的文件名 sheet->setColumn($startCol, $endCol, $width); // 设置列宽度 $sheet->write($row, $col, $data, $format); // 工作表写入数据, $row 写入的行号,从0开始 $col 写入的列号,从0开始 $data 数据 $format 使用addFormat() 创建的样式 $sheet->mergeCells($startRow, $startCol, $endRow, $endCol); // 合并单元格 $workbook->close(); // 完成下载

就是这些了,有时间的话,保存以上代码为xxx.php,自行测试下,看看效果如何,毕竟编程重在动手嘛。



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