03_Column_Formula.php 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  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. $columnFormula = '=SUM(Sales_Data[[#This Row],[Q1]:[Q4]])';
  22. $dataArray = [
  23. ['Year', 'Country', 'Q1', 'Q2', 'Q3', 'Q4', 'Sales'],
  24. [2010, 'Belgium', 380, 390, 420, 460, $columnFormula],
  25. [2010, 'France', 510, 490, 460, 590, $columnFormula],
  26. [2010, 'Germany', 720, 680, 640, 660, $columnFormula],
  27. [2010, 'Italy', 440, 410, 420, 450, $columnFormula],
  28. [2010, 'Spain', 510, 490, 470, 420, $columnFormula],
  29. [2010, 'UK', 690, 610, 620, 600, $columnFormula],
  30. [2010, 'United States', 790, 730, 860, 850, $columnFormula],
  31. [2011, 'Belgium', 400, 350, 450, 500, $columnFormula],
  32. [2011, 'France', 620, 650, 415, 570, $columnFormula],
  33. [2011, 'Germany', 680, 620, 710, 690, $columnFormula],
  34. [2011, 'Italy', 430, 370, 350, 335, $columnFormula],
  35. [2011, 'Spain', 460, 390, 430, 415, $columnFormula],
  36. [2011, 'UK', 720, 650, 580, 510, $columnFormula],
  37. [2011, 'United States', 800, 700, 900, 950, $columnFormula],
  38. ];
  39. $spreadsheet->getActiveSheet()->fromArray($dataArray, null, 'A1');
  40. // Create Table
  41. $helper->log('Create Table');
  42. $table = new Table('A1:G15', 'Sales_Data');
  43. $table->setRange('A1:G15');
  44. // Set Column Formula
  45. $table->getColumn('G')->setColumnFormula($columnFormula);
  46. // Add Table to Worksheet
  47. $helper->log('Add Table to Worksheet');
  48. $spreadsheet->getActiveSheet()->addTable($table);
  49. // Save
  50. $path = $helper->getFilename(__FILE__);
  51. $writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
  52. // Disable precalculation to add table's total row
  53. $writer->setPreCalculateFormulas(false);
  54. $callStartTime = microtime(true);
  55. $writer->save($path);
  56. $helper->logWrite($writer, $path, $callStartTime);
  57. $helper->logEndingNotes();