| 
									
										
										
										
											2016-11-27 09:54:51 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-17 22:02:17 +00:00
										 |  |  | use PhpOffice\PhpSpreadsheet\Spreadsheet; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-27 09:54:51 +00:00
										 |  |  | error_reporting(E_ALL); | 
					
						
							|  |  |  | set_time_limit(0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | date_default_timezone_set('Europe/London'); | 
					
						
							|  |  |  | ?>
 | 
					
						
							|  |  |  | <html> | 
					
						
							| 
									
										
										
										
											2017-08-03 10:03:24 +00:00
										 |  |  |     <head> | 
					
						
							|  |  |  |         <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> | 
					
						
							| 
									
										
										
										
											2016-11-27 09:54:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-03 10:03:24 +00:00
										 |  |  |         <title>PhpSpreadsheet Calculation Examples</title> | 
					
						
							| 
									
										
										
										
											2016-11-27 09:54:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-03 10:03:24 +00:00
										 |  |  |     </head> | 
					
						
							|  |  |  |     <body> | 
					
						
							| 
									
										
										
										
											2016-11-27 09:54:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-03 10:03:24 +00:00
										 |  |  |         <h1>DATEVALUE</h1> | 
					
						
							|  |  |  |         <h2>Converts a date in the form of text to a serial number.</h2> | 
					
						
							|  |  |  |         <?php | 
					
						
							|  |  |  |         require_once __DIR__ . '/../../../../src/Bootstrap.php'; | 
					
						
							| 
									
										
										
										
											2016-11-27 09:54:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-03 10:03:24 +00:00
										 |  |  |         // Create new PhpSpreadsheet object
 | 
					
						
							|  |  |  |         $spreadsheet = new Spreadsheet(); | 
					
						
							|  |  |  |         $worksheet = $spreadsheet->getActiveSheet(); | 
					
						
							| 
									
										
										
										
											2016-11-27 09:54:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-03 10:03:24 +00:00
										 |  |  |         // Add some data
 | 
					
						
							|  |  |  |         $testDates = ['26 March 2012', '29 Feb 2012', 'April 1, 2012', '25/12/2012', | 
					
						
							|  |  |  |             '2012-Oct-31', '5th November', 'January 1st', 'April 2012', | 
					
						
							|  |  |  |             '17-03', '03-2012', '29 Feb 2011', '03-05-07', | 
					
						
							|  |  |  |             '03-MAY-07', '03-13-07', | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |         $testDateCount = count($testDates); | 
					
						
							| 
									
										
										
										
											2016-11-27 09:54:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-03 10:03:24 +00:00
										 |  |  |         for ($row = 1; $row <= $testDateCount; ++$row) { | 
					
						
							|  |  |  |             $worksheet->setCellValue('A' . $row, $testDates[$row - 1]); | 
					
						
							|  |  |  |             $worksheet->setCellValue('B' . $row, '=DATEVALUE(A' . $row . ')'); | 
					
						
							|  |  |  |             $worksheet->setCellValue('C' . $row, '=B' . $row); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-11-27 09:54:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-03 10:03:24 +00:00
										 |  |  |         $worksheet->getStyle('C1:C' . $testDateCount) | 
					
						
							|  |  |  |             ->getNumberFormat() | 
					
						
							|  |  |  |             ->setFormatCode('yyyy-mmm-dd'); | 
					
						
							| 
									
										
										
										
											2016-11-27 09:54:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-03 10:03:24 +00:00
										 |  |  |         echo '<hr />'; | 
					
						
							| 
									
										
										
										
											2016-11-27 09:54:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-03 10:03:24 +00:00
										 |  |  |         // Test the formulae
 | 
					
						
							|  |  |  |         ?>
 | 
					
						
							|  |  |  |         <p><strong>Warning: </strong>The PhpSpreadsheet DATEVALUE() function accepts a wider range of date formats than MS Excel's DATEFORMAT() function.</p> | 
					
						
							|  |  |  |         <table border="1" cellspacing="0"> | 
					
						
							|  |  |  |             <tr> | 
					
						
							|  |  |  |                 <th>Date String</th> | 
					
						
							|  |  |  |                 <th>Formula</th> | 
					
						
							|  |  |  |                 <th>Excel DateStamp</th> | 
					
						
							|  |  |  |                 <th>Formatted DateStamp</th> | 
					
						
							|  |  |  |             </tr> | 
					
						
							|  |  |  |             <?php | 
					
						
							|  |  |  |             for ($row = 1; $row <= $testDateCount; ++$row) { | 
					
						
							|  |  |  |                 echo '<tr>'; | 
					
						
							|  |  |  |                 echo '<td>', $worksheet->getCell('A' . $row)->getFormattedValue(), '</td>'; | 
					
						
							|  |  |  |                 echo '<td>', $worksheet->getCell('B' . $row)->getValue(), '</td>'; | 
					
						
							|  |  |  |                 echo '<td>', $worksheet->getCell('B' . $row)->getFormattedValue(), '</td>'; | 
					
						
							|  |  |  |                 echo '<td>', $worksheet->getCell('C' . $row)->getFormattedValue(), '</td>'; | 
					
						
							|  |  |  |                 echo '</tr>'; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             ?>
 | 
					
						
							|  |  |  |         </table> | 
					
						
							|  |  |  |     </body> | 
					
						
							| 
									
										
										
										
											2017-03-24 13:09:32 +00:00
										 |  |  | </html> |