ACCRINT.php 1.3 KB

1234567891011121314151617181920212223242526272829303132333435
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\Calculation\DateTimeExcel\Helpers as DateHelper;
  3. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  4. require __DIR__ . '/../../Header.php';
  5. $helper->log('Returns the accrued interest for a security that pays periodic interest.');
  6. // Create new PhpSpreadsheet object
  7. $spreadsheet = new Spreadsheet();
  8. $worksheet = $spreadsheet->getActiveSheet();
  9. // Add some data
  10. $arguments = [
  11. ['Issue Date', DateHelper::getDateValue('01-Jan-2012')],
  12. ['First Interest Date', DateHelper::getDateValue('01-Apr-2012')],
  13. ['Settlement Date', DateHelper::getDateValue('31-Dec-2013')],
  14. ['Annual Coupon Rate', 0.08],
  15. ['Par Value', 10000],
  16. ['Frequency', 4],
  17. ];
  18. // Some basic formatting for the data
  19. $worksheet->fromArray($arguments, null, 'A1');
  20. $worksheet->getStyle('B1:B3')->getNumberFormat()->setFormatCode('dd-mmm-yyyy');
  21. $worksheet->getStyle('B4')->getNumberFormat()->setFormatCode('0.00%');
  22. $worksheet->getStyle('B5')->getNumberFormat()->setFormatCode('$#,##0.00');
  23. // Now the formula
  24. $worksheet->setCellValue('B10', '=ACCRINT(B1, B2, B3, B4, B5, B6)');
  25. $worksheet->getStyle('B10')->getNumberFormat()->setFormatCode('$#,##0.00');
  26. $helper->log($worksheet->getCell('B10')->getValue());
  27. $helper->log('ACCRINT() Result is ' . $worksheet->getCell('B10')->getFormattedValue());