EDATE.php 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  3. require __DIR__ . '/../../Header.php';
  4. $category = 'Date/Time';
  5. $functionName = 'EDATE';
  6. $description = 'Returns the serial number that represents the date that is the indicated number of months before or after a specified date';
  7. $helper->titles($category, $functionName, $description);
  8. // Create new PhpSpreadsheet object
  9. $spreadsheet = new Spreadsheet();
  10. $worksheet = $spreadsheet->getActiveSheet();
  11. $months = range(-12, 12);
  12. $testDateCount = count($months);
  13. for ($row = 1; $row <= $testDateCount; ++$row) {
  14. $worksheet->setCellValue('A' . $row, '=DATE(2020,12,31)');
  15. $worksheet->setCellValue('B' . $row, '=A' . $row);
  16. $worksheet->setCellValue('C' . $row, $months[$row - 1]);
  17. $worksheet->setCellValue('D' . $row, '=EDATE(B' . $row . ', C' . $row . ')');
  18. }
  19. $worksheet->getStyle('B1:B' . $testDateCount)
  20. ->getNumberFormat()
  21. ->setFormatCode('yyyy-mm-dd');
  22. $worksheet->getStyle('D1:D' . $testDateCount)
  23. ->getNumberFormat()
  24. ->setFormatCode('yyyy-mm-dd');
  25. // Test the formulae
  26. for ($row = 1; $row <= $testDateCount; ++$row) {
  27. $helper->log(sprintf(
  28. '%s and %d months is %d (%s)',
  29. $worksheet->getCell('B' . $row)->getFormattedValue(),
  30. $worksheet->getCell('C' . $row)->getFormattedValue(),
  31. $worksheet->getCell('D' . $row)->getCalculatedValue(),
  32. $worksheet->getCell('D' . $row)->getFormattedValue()
  33. ));
  34. }