CrossWorksheetNamedFormula.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\NamedFormula;
  3. use PhpOffice\PhpSpreadsheet\Shared\Date;
  4. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  5. use PhpOffice\PhpSpreadsheet\Worksheet\Worksheet;
  6. require_once __DIR__ . '/../Header.php';
  7. $spreadsheet = new Spreadsheet();
  8. $data2019 = [
  9. [151600, 21600],
  10. [160320, 30320],
  11. [243500, 73500],
  12. [113450, 13450],
  13. [143200, 23200],
  14. [134000, 14000],
  15. [89400, -10600],
  16. [184500, 24500],
  17. [100800, 800],
  18. [241850, 5150],
  19. [142425, 12425],
  20. [243400, 43400],
  21. ];
  22. $data2020 = [
  23. [183250, 33250],
  24. [210350, 40350],
  25. [298650, 48650],
  26. [140550, 20550],
  27. [183145, 33145],
  28. [172355, 22355],
  29. ];
  30. $worksheet = $spreadsheet->setActiveSheetIndex(0);
  31. setYearlyData($worksheet, '2019', $data2019);
  32. $worksheet = $spreadsheet->addSheet(new Worksheet($spreadsheet));
  33. setYearlyData($worksheet, '2020', $data2020);
  34. $worksheet = $spreadsheet->addSheet(new Worksheet($spreadsheet));
  35. setYearlyData($worksheet, '2020', [], 'GROWTH');
  36. function setYearlyData(Worksheet $worksheet, string $year, $yearlyData, ?string $title = null): void
  37. {
  38. // Set up some basic data
  39. $worksheetTitle = $title ?: $year;
  40. $worksheet
  41. ->setTitle($worksheetTitle)
  42. ->setCellValue('A1', 'Month')
  43. ->setCellValue('B1', $worksheetTitle === 'GROWTH' ? 'Growth' : 'Sales')
  44. ->setCellValue('C1', $worksheetTitle === 'GROWTH' ? 'Profit Growth' : 'Margin')
  45. ->setCellValue('A2', Date::stringToExcel("{$year}-01-01"));
  46. for ($row = 3; $row <= 13; ++$row) {
  47. $worksheet->setCellValue("A{$row}", '=NEXT_MONTH');
  48. }
  49. if (!empty($yearlyData)) {
  50. $worksheet->fromArray($yearlyData, null, 'B2');
  51. } else {
  52. for ($row = 2; $row <= 13; ++$row) {
  53. $worksheet->setCellValue("B{$row}", '=GROWTH');
  54. $worksheet->setCellValue("C{$row}", '=PROFIT_GROWTH');
  55. }
  56. }
  57. $worksheet->getStyle('A1:C1')
  58. ->getFont()->setBold(true);
  59. $worksheet->getStyle('A2:A13')
  60. ->getNumberFormat()
  61. ->setFormatCode('mmmm');
  62. $worksheet->getStyle('B2:C13')
  63. ->getNumberFormat()
  64. ->setFormatCode($worksheetTitle === 'GROWTH' ? '0.00%' : '_-€* #,##0_-');
  65. }
  66. // Add some Named Formulae
  67. // The first to store our tax rate
  68. $spreadsheet->addNamedFormula(new NamedFormula('NEXT_MONTH', $worksheet, '=EDATE(OFFSET($A1,-1,0),1)'));
  69. $spreadsheet->addNamedFormula(new NamedFormula('GROWTH', $worksheet, "=IF('2020'!\$B1=\"\",\"-\",(('2020'!\$B1/'2019'!\$B1)-1))"));
  70. $spreadsheet->addNamedFormula(new NamedFormula('PROFIT_GROWTH', $worksheet, "=IF('2020'!\$C1=\"\",\"-\",(('2020'!\$C1/'2019'!\$C1)-1))"));
  71. for ($row = 2; $row <= 7; ++$row) {
  72. $month = $worksheet->getCell("A{$row}")->getFormattedValue();
  73. $growth = $worksheet->getCell("B{$row}")->getFormattedValue();
  74. $profitGrowth = $worksheet->getCell("C{$row}")->getFormattedValue();
  75. $helper->log("Growth for {$month} is {$growth}, with a Profit Growth of {$profitGrowth}");
  76. }
  77. $helper->write($spreadsheet, __FILE__, ['Xlsx']);