TIMEVALUE.php 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  3. require __DIR__ . '/../../Header.php';
  4. $category = 'Date/Time';
  5. $functionName = 'DATEVALUE';
  6. $description = 'Converts a time 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 = ['3:15', '13:15', '15:15:15', '3:15 AM', '3:15 PM', '5PM', '9:15AM', '13:15AM',
  13. ];
  14. $testDateCount = count($testDates);
  15. for ($row = 1; $row <= $testDateCount; ++$row) {
  16. $worksheet->setCellValue('A' . $row, $testDates[$row - 1]);
  17. $worksheet->setCellValue('B' . $row, '=TIMEVALUE(A' . $row . ')');
  18. $worksheet->setCellValue('C' . $row, '=B' . $row);
  19. }
  20. $worksheet->getStyle('C1:C' . $testDateCount)
  21. ->getNumberFormat()
  22. ->setFormatCode('hh:mm:ss');
  23. // Test the formulae
  24. for ($row = 1; $row <= $testDateCount; ++$row) {
  25. $helper->log("(A{$row}) Time String: " . $worksheet->getCell('A' . $row)->getFormattedValue());
  26. $helper->log('Formula: ' . $worksheet->getCell('B' . $row)->getValue());
  27. $helper->log('Excel TimeStamp: ' . $worksheet->getCell('B' . $row)->getFormattedValue());
  28. $helper->log('Formatted TimeStamp: ' . $worksheet->getCell('C' . $row)->getFormattedValue());
  29. $helper->log('');
  30. }