100 lines
3.3 KiB
PHP
100 lines
3.3 KiB
PHP
|
<?php
|
||
|
|
||
|
use PhpOffice\PhpSpreadsheet\IOFactory;
|
||
|
use PhpOffice\PhpSpreadsheet\NamedFormula;
|
||
|
use PhpOffice\PhpSpreadsheet\Shared\Date;
|
||
|
use PhpOffice\PhpSpreadsheet\Spreadsheet;
|
||
|
use PhpOffice\PhpSpreadsheet\Worksheet\Worksheet;
|
||
|
|
||
|
error_reporting(E_ALL);
|
||
|
set_time_limit(0);
|
||
|
|
||
|
date_default_timezone_set('UTC');
|
||
|
|
||
|
// Adjust the path as required to reference the PHPSpreadsheet Bootstrap file
|
||
|
require_once __DIR__ . '/../Bootstrap.php';
|
||
|
|
||
|
$spreadsheet = new Spreadsheet();
|
||
|
|
||
|
$data2019 = [
|
||
|
[151600, 21600],
|
||
|
[160320, 30320],
|
||
|
[243500, 73500],
|
||
|
[113450, 13450],
|
||
|
[143200, 23200],
|
||
|
[134000, 14000],
|
||
|
[89400, -10600],
|
||
|
[184500, 24500],
|
||
|
[100800, 800],
|
||
|
[241850, 5150],
|
||
|
[142425, 12425],
|
||
|
[243400, 43400],
|
||
|
];
|
||
|
|
||
|
$data2020 = [
|
||
|
[183250, 33250],
|
||
|
[210350, 40350],
|
||
|
[298650, 48650],
|
||
|
[140550, 20550],
|
||
|
[183145, 33145],
|
||
|
[172355, 22355],
|
||
|
];
|
||
|
|
||
|
$worksheet = $spreadsheet->setActiveSheetIndex(0);
|
||
|
setYearlyData($worksheet, '2019', $data2019);
|
||
|
$worksheet = $spreadsheet->addSheet(new Worksheet($spreadsheet));
|
||
|
setYearlyData($worksheet, '2020', $data2020);
|
||
|
$worksheet = $spreadsheet->addSheet(new Worksheet($spreadsheet));
|
||
|
setYearlyData($worksheet, '2020', [], 'GROWTH');
|
||
|
|
||
|
function setYearlyData(Worksheet $worksheet, string $year, $yearlyData, ?string $title = null): void
|
||
|
{
|
||
|
// Set up some basic data
|
||
|
$worksheetTitle = $title ?: $year;
|
||
|
$worksheet
|
||
|
->setTitle($worksheetTitle)
|
||
|
->setCellValue('A1', 'Month')
|
||
|
->setCellValue('B1', $worksheetTitle === 'GROWTH' ? 'Growth' : 'Sales')
|
||
|
->setCellValue('C1', $worksheetTitle === 'GROWTH' ? 'Profit Growth' : 'Margin')
|
||
|
->setCellValue('A2', Date::stringToExcel("{$year}-01-01"));
|
||
|
for ($row = 3; $row <= 13; ++$row) {
|
||
|
$worksheet->setCellValue("A{$row}", '=NEXT_MONTH');
|
||
|
}
|
||
|
|
||
|
if (!empty($yearlyData)) {
|
||
|
$worksheet->fromArray($yearlyData, null, 'B2');
|
||
|
} else {
|
||
|
for ($row = 2; $row <= 13; ++$row) {
|
||
|
$worksheet->setCellValue("B{$row}", '=GROWTH');
|
||
|
$worksheet->setCellValue("C{$row}", '=PROFIT_GROWTH');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$worksheet->getStyle('A1:C1')
|
||
|
->getFont()->setBold(true);
|
||
|
$worksheet->getStyle('A2:A13')
|
||
|
->getNumberFormat()
|
||
|
->setFormatCode('mmmm');
|
||
|
$worksheet->getStyle('B2:C13')
|
||
|
->getNumberFormat()
|
||
|
->setFormatCode($worksheetTitle === 'GROWTH' ? '0.00%' : '_-€* #,##0_-');
|
||
|
}
|
||
|
|
||
|
// Add some Named Formulae
|
||
|
// The first to store our tax rate
|
||
|
$spreadsheet->addNamedFormula(new NamedFormula('NEXT_MONTH', $worksheet, '=EDATE(OFFSET($A1,-1,0),1)'));
|
||
|
$spreadsheet->addNamedFormula(new NamedFormula('GROWTH', $worksheet, "=IF('2020'!\$B1=\"\",\"-\",(('2020'!\$B1/'2019'!\$B1)-1))"));
|
||
|
$spreadsheet->addNamedFormula(new NamedFormula('PROFIT_GROWTH', $worksheet, "=IF('2020'!\$C1=\"\",\"-\",(('2020'!\$C1/'2019'!\$C1)-1))"));
|
||
|
|
||
|
for ($row = 2; $row <= 7; ++$row) {
|
||
|
$month = $worksheet->getCell("A{$row}")->getFormattedValue();
|
||
|
$growth = $worksheet->getCell("B{$row}")->getFormattedValue();
|
||
|
$profitGrowth = $worksheet->getCell("C{$row}")->getFormattedValue();
|
||
|
|
||
|
echo "Growth for {$month} is {$growth}, with a Profit Growth of {$profitGrowth}", PHP_EOL;
|
||
|
}
|
||
|
|
||
|
$outputFileName = 'CrossWorksheetNamedFormula.xlsx';
|
||
|
$writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
|
||
|
$writer->save($outputFileName);
|