DATEVALUE.php 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  3. require __DIR__ . '/../../Header.php';
  4. $category = 'Date/Time';
  5. $functionName = 'DATEVALUE';
  6. $description = 'Converts a date in the form of text to an Excel serial number';
  7. $helper->titles($category, $functionName, $description);
  8. // Create new PhpSpreadsheet object
  9. $spreadsheet = new Spreadsheet();
  10. $worksheet = $spreadsheet->getActiveSheet();
  11. // Add some data
  12. $testDates = ['26 March 2012', '29 Feb 2012', 'April 1, 2012', '25/12/2012',
  13. '2012-Oct-31', '5th November', 'January 1st', 'April 2012',
  14. '17-03', '03-17', '03-2012', '29 Feb 2011', '03-05-07',
  15. '03-MAY-07', '03-13-07', '13-03-07', '03/13/07', '13/03/07',
  16. ];
  17. $testDateCount = count($testDates);
  18. for ($row = 1; $row <= $testDateCount; ++$row) {
  19. $worksheet->setCellValue('A' . $row, $testDates[$row - 1]);
  20. $worksheet->setCellValue('B' . $row, '=DATEVALUE(A' . $row . ')');
  21. $worksheet->setCellValue('C' . $row, '=B' . $row);
  22. }
  23. $worksheet->getStyle('C1:C' . $testDateCount)
  24. ->getNumberFormat()
  25. ->setFormatCode('yyyy-mm-dd');
  26. // Test the formulae
  27. $helper->log('<strong>Warning: </strong>The PhpSpreadsheet DATEVALUE() function accepts a wider range of date formats than MS Excel DATEFORMAT() function.');
  28. for ($row = 1; $row <= $testDateCount; ++$row) {
  29. $helper->log("(A{$row}) Date String: " . $worksheet->getCell('A' . $row)->getFormattedValue());
  30. $helper->log('Formula: ' . $worksheet->getCell('B' . $row)->getValue());
  31. $helper->log('Excel DateStamp: ' . $worksheet->getCell('B' . $row)->getCalculatedValue());
  32. $helper->log('Formatted DateStamp: ' . $worksheet->getCell('C' . $row)->getFormattedValue());
  33. $helper->log('');
  34. }