SimpleNamedFormula.php 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\NamedFormula;
  3. use PhpOffice\PhpSpreadsheet\NamedRange;
  4. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  5. require_once __DIR__ . '/../Header.php';
  6. $spreadsheet = new Spreadsheet();
  7. $worksheet = $spreadsheet->setActiveSheetIndex(0);
  8. // Add some Named Formulae
  9. // The first to store our tax rate
  10. $spreadsheet->addNamedFormula(new NamedFormula('TAX_RATE', $worksheet, '=19%'));
  11. // The second to calculate the Tax on a Price value (Note that `PRICE` is defined later as a Named Range)
  12. $spreadsheet->addNamedFormula(new NamedFormula('TAX', $worksheet, '=PRICE*TAX_RATE'));
  13. // Set up some basic data
  14. $worksheet
  15. ->setCellValue('A1', 'Tax Rate:')
  16. ->setCellValue('B1', '=TAX_RATE')
  17. ->setCellValue('A3', 'Net Price:')
  18. ->setCellValue('B3', 19.99)
  19. ->setCellValue('A4', 'Tax:')
  20. ->setCellValue('A5', 'Price including Tax:');
  21. // Define a named range that we can use in our formulae
  22. $spreadsheet->addNamedRange(new NamedRange('PRICE', $worksheet, '=$B$3'));
  23. // Reference the defined formulae in worksheet formulae
  24. $worksheet
  25. ->setCellValue('B4', '=TAX')
  26. ->setCellValue('B5', '=PRICE+TAX');
  27. $helper->log(sprintf(
  28. 'With a Tax Rate of %.2f and a net price of %.2f, Tax is %.2f and the gross price is %.2f',
  29. $worksheet->getCell('B1')->getCalculatedValue(),
  30. $worksheet->getCell('B3')->getValue(),
  31. $worksheet->getCell('B4')->getCalculatedValue(),
  32. $worksheet->getCell('B5')->getCalculatedValue()
  33. ));
  34. $helper->write($spreadsheet, __FILE__, ['Xlsx']);