Xls(x) Readers now respect the readBlankCells setting. (#835)
* Prevented reading of blank cells. The "readEmptyCells" attribute is ignored when reading spreadsheets, resulting in memory bloat. * Included a test file for Unit Testing A file that contains 100 referenced cells, one of which contains data. * New test file for reading in empty cells * Added test for reading in a blank cell * Updated CHANGELOG * Changed "s to 's Change required for code style compliance * Further Code Style Changes Removed spaces after variable, before array indices. * Further Code Style Changes * Further Code Style Changes Removed additional spaces. * Updated reader and tests.
This commit is contained in:
		
							parent
							
								
									15abdf43ad
								
							
						
					
					
						commit
						98d1782bbb
					
				| @ -32,6 +32,7 @@ and this project adheres to [Semantic Versioning](https://semver.org). | ||||
| 
 | ||||
| - Improve XLSX parsing speed if no readFilter is applied - [#772](https://github.com/PHPOffice/PhpSpreadsheet/issues/772) | ||||
| - Fix column names if read filter calls in XLSX reader skip columns - [#777](https://github.com/PHPOffice/PhpSpreadsheet/pull/777) | ||||
| - XLSX reader can now ignore blank cells, using the setReadEmptyCells(false) method. - [#810](https://github.com/PHPOffice/PhpSpreadsheet/issues/810) | ||||
| - Fix LOOKUP function which was breaking on edge cases - [#796](https://github.com/PHPOffice/PhpSpreadsheet/issues/796) | ||||
| - Fix VLOOKUP with exact matches - [#809](https://github.com/PHPOffice/PhpSpreadsheet/pull/809) | ||||
| - Support COUNTIFS multiple arguments - [#830](https://github.com/PHPOffice/PhpSpreadsheet/pull/830) | ||||
|  | ||||
| @ -972,6 +972,8 @@ class Xlsx extends BaseReader | ||||
|                                                 break; | ||||
|                                         } | ||||
| 
 | ||||
|                                         // read empty cells or the cells are not empty
 | ||||
|                                         if ($this->readEmptyCells || ($value !== null && $value !== '')) { | ||||
|                                             // Check for numeric values
 | ||||
|                                             if (is_numeric($value) && $cellDataType != 's') { | ||||
|                                                 if ($value == (int) $value) { | ||||
| @ -1005,6 +1007,7 @@ class Xlsx extends BaseReader | ||||
|                                                 $cell->setXfIndex(isset($styles[(int) ($c['s'])]) ? | ||||
|                                                     (int) ($c['s']) : 0); | ||||
|                                             } | ||||
|                                         } | ||||
|                                         $rowIndex += 1; | ||||
|                                     } | ||||
|                                     $cIndex += 1; | ||||
|  | ||||
							
								
								
									
										50
									
								
								tests/PhpSpreadsheetTests/Functional/ReadBlankCellsTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								tests/PhpSpreadsheetTests/Functional/ReadBlankCellsTest.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,50 @@ | ||||
| <?php | ||||
| 
 | ||||
| namespace PhpOffice\PhpSpreadsheetTests\Functional; | ||||
| 
 | ||||
| use PhpOffice\PhpSpreadsheet\Reader\IReadFilter; | ||||
| use PhpOffice\PhpSpreadsheet\Spreadsheet; | ||||
| 
 | ||||
| class ReadBlankCellsTest extends AbstractFunctional | ||||
| { | ||||
| 
 | ||||
|     public function providerSheetFormat() | ||||
|     { | ||||
|         return [ | ||||
|             ['Xlsx'], | ||||
|             ['Xls'], | ||||
|             // ['Ods'], // Broken. Requires fix in Ods reader.
 | ||||
|             // ['Csv'], // never reads blank cells
 | ||||
|             // ['Html'], // never reads blank cells
 | ||||
|         ]; | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Test generate file with some empty cells | ||||
|      * | ||||
|      * @dataProvider providerSheetFormat | ||||
|      * | ||||
|      * @param array $arrayData | ||||
|      * @param mixed $format | ||||
|      */ | ||||
|     public function testXlsxLoadWithNoBlankCells($format) | ||||
|     { | ||||
|         $spreadsheet = new Spreadsheet(); | ||||
|         $spreadsheet->getActiveSheet()->getCell('B2')->setValue(''); | ||||
|         $spreadsheet->getActiveSheet()->getCell('C1')->setValue('C1'); | ||||
|         $spreadsheet->getActiveSheet()->getCell('C3')->setValue('C3'); | ||||
| 
 | ||||
|         $reloadedSpreadsheet = $this->writeAndReload($spreadsheet, $format); | ||||
|         $this->assertTrue($reloadedSpreadsheet->getActiveSheet()->getCellCollection()->has('B2')); | ||||
|         $this->assertFalse($reloadedSpreadsheet->getActiveSheet()->getCellCollection()->has('C2')); | ||||
|         $this->assertTrue($reloadedSpreadsheet->getActiveSheet()->getCellCollection()->has('C3')); | ||||
| 
 | ||||
|         $reloadedSpreadsheet = $this->writeAndReload($spreadsheet, $format, function($reader) { | ||||
|             $reader->setReadEmptyCells(false); | ||||
|         }); | ||||
|         $this->assertFalse($reloadedSpreadsheet->getActiveSheet()->getCellCollection()->has('B2')); | ||||
|         $this->assertFalse($reloadedSpreadsheet->getActiveSheet()->getCellCollection()->has('C2')); | ||||
|         $this->assertTrue($reloadedSpreadsheet->getActiveSheet()->getCellCollection()->has('C3')); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 phinor
						phinor