NPER.php 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\Calculation\Financial\Constants as FinancialConstants;
  3. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  4. require __DIR__ . '/../../Header.php';
  5. $helper->log('Returns the number of periods required to pay off a loan, for a constant periodic payment');
  6. $helper->log('and a constant interest rate.');
  7. // Create new PhpSpreadsheet object
  8. $spreadsheet = new Spreadsheet();
  9. $worksheet = $spreadsheet->getActiveSheet();
  10. // Add some data
  11. $arguments = [
  12. ['Interest Rate', 0.04, 0.06],
  13. ['Payments per Year', 1, 4],
  14. ['Payment Amount', -6000.00, -2000],
  15. ['Present Value', 50000, 60000],
  16. ['Future Value', null, 30000],
  17. ['Payment Type', null, FinancialConstants::PAYMENT_BEGINNING_OF_PERIOD],
  18. ];
  19. // Some basic formatting for the data
  20. $worksheet->fromArray($arguments, null, 'A1');
  21. $worksheet->getStyle('B1:C1')->getNumberFormat()->setFormatCode('0.00%');
  22. $worksheet->getStyle('B3:C5')->getNumberFormat()->setFormatCode('$#,##0.00');
  23. // Now the formula
  24. $worksheet->setCellValue('B8', '=NPER(B1/B2, B3, B4)');
  25. $helper->log($worksheet->getCell('B8')->getValue());
  26. $helper->log('NPER() Result is ' . $worksheet->getCell('B8')->getFormattedValue());
  27. $worksheet->setCellValue('C8', '=NPER(C1/C2, C3, C4, C5, C6)');
  28. $helper->log($worksheet->getCell('C8')->getValue());
  29. $helper->log('NPER() Result is ' . $worksheet->getCell('C8')->getFormattedValue());