DB.php 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  3. require __DIR__ . '/../../Header.php';
  4. $helper->log('Returns the depreciation of an asset, using the Fixed Declining Balance Method,');
  5. $helper->log('for each period of the asset\'s lifetime.');
  6. // Create new PhpSpreadsheet object
  7. $spreadsheet = new Spreadsheet();
  8. $worksheet = $spreadsheet->getActiveSheet();
  9. // Add some data
  10. $arguments = [
  11. ['Cost Value', 10000],
  12. ['Salvage', 1000],
  13. ['Life', 5, 'Years'],
  14. ];
  15. // Some basic formatting for the data
  16. $worksheet->fromArray($arguments, null, 'A1');
  17. $worksheet->getStyle('B1:B2')->getNumberFormat()->setFormatCode('$#,##0.00');
  18. // Now the formula
  19. $baseRow = 5;
  20. for ($year = 1; $year <= 5; ++$year) {
  21. $row = (string) ($baseRow + $year);
  22. $worksheet->setCellValue("A{$row}", "Depreciation after Yr {$year}");
  23. $worksheet->setCellValue("B{$row}", "=DB(\$B\$1, \$B\$2, \$B\$3, {$year})");
  24. $worksheet->getStyle("B{$row}")->getNumberFormat()->setFormatCode('$#,##0.00;-$#,##0.00');
  25. $helper->log($worksheet->getCell("B{$row}")->getValue());
  26. $helper->log("DB() Year {$year} Result is " . $worksheet->getCell("B{$row}")->getFormattedValue());
  27. }
  28. $helper->log('And with depreciation only starting after 6 months.');
  29. $baseRow = 12;
  30. for ($year = 1; $year <= 6; ++$year) {
  31. $row = (string) ($baseRow + $year);
  32. $worksheet->setCellValue("A{$row}", "Depreciation after Yr {$year}");
  33. $worksheet->setCellValue("B{$row}", "=DB(\$B\$1, \$B\$2, \$B\$3, {$year}, 6)");
  34. $worksheet->getStyle("B{$row}")->getNumberFormat()->setFormatCode('$#,##0.00;-$#,##0.00');
  35. $helper->log($worksheet->getCell("B{$row}")->getValue());
  36. $helper->log("DB() Year {$year} Result is " . $worksheet->getCell("B{$row}")->getFormattedValue());
  37. }