SimpleNamedRange.php 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\NamedRange;
  3. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  4. require_once __DIR__ . '/../Header.php';
  5. $spreadsheet = new Spreadsheet();
  6. $worksheet = $spreadsheet->setActiveSheetIndex(0);
  7. // Set up some basic data
  8. $worksheet
  9. ->setCellValue('A1', 'Tax Rate:')
  10. ->setCellValue('B1', '=19%')
  11. ->setCellValue('A3', 'Net Price:')
  12. ->setCellValue('B3', 12.99)
  13. ->setCellValue('A4', 'Tax:')
  14. ->setCellValue('A5', 'Price including Tax:');
  15. // Define named ranges
  16. $spreadsheet->addNamedRange(new NamedRange('TAX_RATE', $worksheet, '=$B$1'));
  17. $spreadsheet->addNamedRange(new NamedRange('PRICE', $worksheet, '=$B$3'));
  18. // Reference that defined name in a formula
  19. $worksheet
  20. ->setCellValue('B4', '=PRICE*TAX_RATE')
  21. ->setCellValue('B5', '=PRICE*(1+TAX_RATE)');
  22. $helper->log(sprintf(
  23. 'With a Tax Rate of %.2f and a net price of %.2f, Tax is %.2f and the gross price is %.2f',
  24. $worksheet->getCell('B1')->getCalculatedValue(),
  25. $worksheet->getCell('B3')->getValue(),
  26. $worksheet->getCell('B4')->getCalculatedValue(),
  27. $worksheet->getCell('B5')->getCalculatedValue()
  28. ));
  29. $helper->write($spreadsheet, __FILE__, ['Xlsx']);