IPMT.php 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  3. require __DIR__ . '/../../Header.php';
  4. $helper->log('Returns the interest payment, during a specific period of a loan or investment that is paid in,');
  5. $helper->log('constant periodic payments, with a constant interest rate.');
  6. // Create new PhpSpreadsheet object
  7. $spreadsheet = new Spreadsheet();
  8. $worksheet = $spreadsheet->getActiveSheet();
  9. // Add some data
  10. $arguments = [
  11. ['Interest Rate', 0.05],
  12. ['Number of Years', 5],
  13. ['Present Value', 50000.00],
  14. ];
  15. // Some basic formatting for the data
  16. $worksheet->fromArray($arguments, null, 'A1');
  17. $worksheet->getStyle('B1')->getNumberFormat()->setFormatCode('0.00%');
  18. $worksheet->getStyle('B3')->getNumberFormat()->setFormatCode('$#,##0.00');
  19. // Now the formula
  20. $baseRow = 6;
  21. for ($month = 1; $month <= 12; ++$month) {
  22. $row = (string) ($baseRow + $month);
  23. $worksheet->setCellValue("A{$row}", "Payment for Mth {$month}");
  24. $worksheet->setCellValue("B{$row}", "=IPMT(\$B\$1/12, {$month}, \$B\$2*12, \$B\$3)");
  25. $worksheet->getStyle("B{$row}")->getNumberFormat()->setFormatCode('$#,##0.00;-$#,##0.00');
  26. $helper->log($worksheet->getCell("B{$row}")->getValue());
  27. $helper->log("IPMT() Month {$month} Result is " . $worksheet->getCell("B{$row}")->getFormattedValue());
  28. }