72 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			72 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
|   | <?php | ||
|  | 
 | ||
|  | error_reporting(E_ALL); | ||
|  | set_time_limit(0); | ||
|  | 
 | ||
|  | date_default_timezone_set('Europe/London'); | ||
|  | 
 | ||
|  | ?>
 | ||
|  | <html> | ||
|  | <head> | ||
|  | <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> | ||
|  | 
 | ||
|  | <title>PHPExcel Calculation Examples</title> | ||
|  | 
 | ||
|  | </head> | ||
|  | <body> | ||
|  | 
 | ||
|  | <h1>DATEVALUE</h1> | ||
|  | <h2>Converts a date in the form of text to a serial number.</h2> | ||
|  | <?php | ||
|  | 
 | ||
|  | /** Include path **/ | ||
|  | set_include_path(get_include_path() . PATH_SEPARATOR . '../../../../Classes/'); | ||
|  | 
 | ||
|  | /** Include PHPExcel */ | ||
|  | include 'PHPExcel.php'; | ||
|  | 
 | ||
|  | // Create new PHPExcel object
 | ||
|  | $objPHPExcel = new PHPExcel(); | ||
|  | $worksheet = $objPHPExcel->getActiveSheet(); | ||
|  | 
 | ||
|  | // 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); | ||
|  | 
 | ||
|  | 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); | ||
|  | } | ||
|  | 
 | ||
|  | $worksheet->getStyle('C1:C' . $testDateCount) | ||
|  |           ->getNumberFormat() | ||
|  |           ->setFormatCode('yyyy-mmm-dd'); | ||
|  | 
 | ||
|  | echo '<hr />'; | ||
|  | 
 | ||
|  | // Test the formulae
 | ||
|  | ?>
 | ||
|  | <p><strong>Warning: </strong>The PHPExcel 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> |