TIME.php 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  3. require __DIR__ . '/../../Header.php';
  4. $category = 'Date/Time';
  5. $functionName = 'TIME';
  6. $description = 'Returns the Excel serial number of a particular time';
  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, 30],
  13. [15, 15, 15], [5], [9, 15, 0], [9, 15, -1],
  14. [13, -14, -15], [0, 0, -1],
  15. ];
  16. $testDateCount = count($testDates);
  17. $worksheet->fromArray($testDates, null, 'A1', true);
  18. for ($row = 1; $row <= $testDateCount; ++$row) {
  19. $worksheet->setCellValue('D' . $row, '=TIME(A' . $row . ',B' . $row . ',C' . $row . ')');
  20. $worksheet->setCellValue('E' . $row, '=D' . $row);
  21. }
  22. $worksheet->getStyle('E1:E' . $testDateCount)
  23. ->getNumberFormat()
  24. ->setFormatCode('hh:mm:ss');
  25. // Test the formulae
  26. for ($row = 1; $row <= $testDateCount; ++$row) {
  27. $helper->log("(A{$row}) Hour: " . $worksheet->getCell('A' . $row)->getFormattedValue());
  28. $helper->log("(B{$row}) Minute: " . $worksheet->getCell('B' . $row)->getFormattedValue());
  29. $helper->log("(C{$row}) Second: " . $worksheet->getCell('C' . $row)->getFormattedValue());
  30. $helper->log('Formula: ' . $worksheet->getCell('D' . $row)->getValue());
  31. $helper->log('Excel TimeStamp: ' . $worksheet->getCell('D' . $row)->getCalculatedValue());
  32. $helper->log('Formatted TimeStamp: ' . $worksheet->getCell('E' . $row)->getFormattedValue());
  33. $helper->log('');
  34. }