02_Table_Total.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\IOFactory;
  3. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  4. use PhpOffice\PhpSpreadsheet\Worksheet\Table;
  5. require __DIR__ . '/../Header.php';
  6. // Create new Spreadsheet object
  7. $helper->log('Create new Spreadsheet object');
  8. $spreadsheet = new Spreadsheet();
  9. // Set document properties
  10. $helper->log('Set document properties');
  11. $spreadsheet->getProperties()->setCreator('aswinkumar863')
  12. ->setLastModifiedBy('aswinkumar863')
  13. ->setTitle('PhpSpreadsheet Table Test Document')
  14. ->setSubject('PhpSpreadsheet Table Test Document')
  15. ->setDescription('Test document for PhpSpreadsheet, generated using PHP classes.')
  16. ->setKeywords('office PhpSpreadsheet php')
  17. ->setCategory('Table');
  18. // Create the worksheet
  19. $helper->log('Add data');
  20. $spreadsheet->setActiveSheetIndex(0);
  21. $spreadsheet->getActiveSheet()->setCellValue('A1', 'Year')
  22. ->setCellValue('B1', 'Quarter')
  23. ->setCellValue('C1', 'Country')
  24. ->setCellValue('D1', 'Sales');
  25. $dataArray = [
  26. ['2010', 'Q1', 'United States', 790],
  27. ['2010', 'Q2', 'United States', 730],
  28. ['2010', 'Q3', 'United States', 860],
  29. ['2010', 'Q4', 'United States', 850],
  30. ['2011', 'Q1', 'United States', 800],
  31. ['2011', 'Q2', 'United States', 700],
  32. ['2011', 'Q3', 'United States', 900],
  33. ['2011', 'Q4', 'United States', 950],
  34. ['2010', 'Q1', 'Belgium', 380],
  35. ['2010', 'Q2', 'Belgium', 390],
  36. ['2010', 'Q3', 'Belgium', 420],
  37. ['2010', 'Q4', 'Belgium', 460],
  38. ['2011', 'Q1', 'Belgium', 400],
  39. ['2011', 'Q2', 'Belgium', 350],
  40. ['2011', 'Q3', 'Belgium', 450],
  41. ['2011', 'Q4', 'Belgium', 500],
  42. ];
  43. $spreadsheet->getActiveSheet()->fromArray($dataArray, null, 'A2');
  44. // Table
  45. $helper->log('Create Table');
  46. $table = new Table();
  47. $table->setName('SalesData');
  48. $table->setShowTotalsRow(true);
  49. $table->setRange('A1:D18'); // +1 row for totalsRow
  50. $helper->log('Add Totals Row');
  51. // Table column label not implemented yet,
  52. $table->getColumn('A')->setTotalsRowLabel('Total');
  53. // So set the label directly to the cell
  54. $spreadsheet->getActiveSheet()->getCell('A18')->setValue('Total');
  55. // Table column function not implemented yet,
  56. $table->getColumn('D')->setTotalsRowFunction('sum');
  57. // So set the formula directly to the cell
  58. $spreadsheet->getActiveSheet()->getCell('D18')->setValue('=SUBTOTAL(109,SalesData[Sales])');
  59. // Add Table to Worksheet
  60. $helper->log('Add Table to Worksheet');
  61. $spreadsheet->getActiveSheet()->addTable($table);
  62. // Save
  63. $path = $helper->getFilename(__FILE__);
  64. $writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
  65. // Disable precalculation to add table's total row
  66. $writer->setPreCalculateFormulas(false);
  67. $callStartTime = microtime(true);
  68. $writer->save($path);
  69. $helper->logWrite($writer, $path, $callStartTime);
  70. $helper->logEndingNotes();