General: Fix to calculation properties for Excel2007 so that the opening application will only recalculate on load if it's actually required
General: Modified Excel2007 Writer to default preCalculateFormulas to false
         Note that autosize columns will still recalculate affected formulae internally
			
			
This commit is contained in:
		
							parent
							
								
									555a4ab828
								
							
						
					
					
						commit
						68a0918ceb
					
				| @ -35,6 +35,17 @@ | |||||||
|  */ |  */ | ||||||
| class PHPExcel_Writer_Excel2007 extends PHPExcel_Writer_Abstract implements PHPExcel_Writer_IWriter | class PHPExcel_Writer_Excel2007 extends PHPExcel_Writer_Abstract implements PHPExcel_Writer_IWriter | ||||||
| { | { | ||||||
|  | 	/** | ||||||
|  | 	 * Pre-calculate formulas | ||||||
|  | 	 * Forces PHPExcel to recalculate all formulae in a workbook when saving, so that the pre-calculated values are | ||||||
|  | 	 *    immediately available to MS Excel or other office spreadsheet viewer when opening the file | ||||||
|  | 	 * | ||||||
|  |      * Overrides the default TRUE for this specific writer for performance reasons | ||||||
|  |      * | ||||||
|  | 	 * @var boolean | ||||||
|  | 	 */ | ||||||
|  | 	protected $_preCalculateFormulas = FALSE; | ||||||
|  | 
 | ||||||
| 	/** | 	/** | ||||||
| 	 * Office2003 compatibility | 	 * Office2003 compatibility | ||||||
| 	 * | 	 * | ||||||
|  | |||||||
| @ -194,10 +194,14 @@ class PHPExcel_Writer_Excel2007_Workbook extends PHPExcel_Writer_Excel2007_Write | |||||||
| 	{ | 	{ | ||||||
| 		$objWriter->startElement('calcPr'); | 		$objWriter->startElement('calcPr'); | ||||||
| 
 | 
 | ||||||
| 		$objWriter->writeAttribute('calcId', 			'124519'); | 		//	Set the calcid to a higher value than Excel itself will use, otherwise Excel will always recalc
 | ||||||
|  |         //  If MS Excel does do a recalc, then users opening a file in MS Excel will be prompted to save on exit
 | ||||||
|  |         //     because the file has changed
 | ||||||
|  | 		$objWriter->writeAttribute('calcId', 			'999999'); | ||||||
| 		$objWriter->writeAttribute('calcMode', 			'auto'); | 		$objWriter->writeAttribute('calcMode', 			'auto'); | ||||||
| 		//	fullCalcOnLoad isn't needed if we've recalculating for the save
 | 		//	fullCalcOnLoad isn't needed if we've recalculating for the save
 | ||||||
| 		$objWriter->writeAttribute('fullCalcOnLoad', 	($recalcRequired) ? '0' : '1'); | 		$objWriter->writeAttribute('calcCompleted', 	($recalcRequired) ? 1 : 0); | ||||||
|  | 		$objWriter->writeAttribute('fullCalcOnLoad', 	($recalcRequired) ? 0 : 1); | ||||||
| 
 | 
 | ||||||
| 		$objWriter->endElement(); | 		$objWriter->endElement(); | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -107,6 +107,15 @@ echo date('H:i:s') , " Write to Excel2007 format" , EOL; | |||||||
| $callStartTime = microtime(true); | $callStartTime = microtime(true); | ||||||
| 
 | 
 | ||||||
| $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007'); | $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007'); | ||||||
|  | 
 | ||||||
|  | //
 | ||||||
|  | //  If we set Pre Calculated Formulas to true then PHPExcel will calculate all formulae in the
 | ||||||
|  | //    workbook before saving. This adds time and memory overhead, and can cause some problems with formulae
 | ||||||
|  | //    using functions or features (such as array formulae) that aren't yet supported by the calculation engine
 | ||||||
|  | //  If the value is false (the default) for the Excel2007 Writer, then MS Excel (or the application used to
 | ||||||
|  | //    open the file) will need to recalculate values itself to guarantee that the correct results are available.
 | ||||||
|  | //
 | ||||||
|  | //$objWriter->setPreCalculateFormulas(true);
 | ||||||
| $objWriter->save(str_replace('.php', '.xlsx', __FILE__)); | $objWriter->save(str_replace('.php', '.xlsx', __FILE__)); | ||||||
| $callEndTime = microtime(true); | $callEndTime = microtime(true); | ||||||
| $callTime = $callEndTime - $callStartTime; | $callTime = $callEndTime - $callStartTime; | ||||||
|  | |||||||
| @ -207,6 +207,15 @@ echo date('H:i:s') , " Write to Excel2007 format" , EOL; | |||||||
| $callStartTime = microtime(true); | $callStartTime = microtime(true); | ||||||
| 
 | 
 | ||||||
| $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007'); | $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007'); | ||||||
|  | 
 | ||||||
|  | //
 | ||||||
|  | //  If we set Pre Calculated Formulas to true then PHPExcel will calculate all formulae in the
 | ||||||
|  | //    workbook before saving. This adds time and memory overhead, and can cause some problems with formulae
 | ||||||
|  | //    using functions or features (such as array formulae) that aren't yet supported by the calculation engine
 | ||||||
|  | //  If the value is false (the default) for the Excel2007 Writer, then MS Excel (or the application used to
 | ||||||
|  | //    open the file) will need to recalculate values itself to guarantee that the correct results are available.
 | ||||||
|  | //
 | ||||||
|  | //$objWriter->setPreCalculateFormulas(true);
 | ||||||
| $objWriter->save(str_replace('.php', '.xlsx', __FILE__)); | $objWriter->save(str_replace('.php', '.xlsx', __FILE__)); | ||||||
| $callEndTime = microtime(true); | $callEndTime = microtime(true); | ||||||
| $callTime = $callEndTime - $callStartTime; | $callTime = $callEndTime - $callStartTime; | ||||||
|  | |||||||
| @ -33,6 +33,10 @@ Fixed in develop branch for release v1.8.0: | |||||||
| - Feature:  (MBaker)                     - Added Horizontal FILL alignment for Excel5 and Excel2007 Readers/Writers, and Horizontal DISTRIBUTED alignment for Excel2007 Reader/Writer | - Feature:  (MBaker)                     - Added Horizontal FILL alignment for Excel5 and Excel2007 Readers/Writers, and Horizontal DISTRIBUTED alignment for Excel2007 Reader/Writer | ||||||
| - General:  (cdhutch)   Work item 20055  - Remove array_shift in ReferenceHelper::insertNewBefore improves column or row delete speed | - General:  (cdhutch)   Work item 20055  - Remove array_shift in ReferenceHelper::insertNewBefore improves column or row delete speed | ||||||
| - General:  (MBaker)                     - Improve stock chart handling and rendering, with help from Swashata Ghosh | - General:  (MBaker)                     - Improve stock chart handling and rendering, with help from Swashata Ghosh | ||||||
|  | - General:  (MBaker)                     - Fix to calculation properties for Excel2007 so that the opening application will only recalculate on load | ||||||
|  |                                              if it's actually required | ||||||
|  | - General:  (MBaker)                     - Modified Excel2007 Writer to default preCalculateFormulas to false | ||||||
|  |                                            Note that autosize columns will still recalculate affected formulae internally | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| Fixed in develop branch for release v1.7.9: | Fixed in develop branch for release v1.7.9: | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Mark Baker
						Mark Baker