Heim > Artikel > Backend-Entwicklung > Welche Lösungen gibt es für den Speicherüberlauf beim Importieren großer Datenmengen in PHPExcel?
PHPExcel-Version: 1.7.6+
Ohne spezielle Einstellungen speichert PHPExcel die gelesenen Zelleninformationen im Speicher, wir können verschiedene Einstellungen vornehmen Caching-Methoden durch PHPExcel_Settings::setCacheStorageMethod()
, um den Zweck der Reduzierung des Speicherverbrauchs zu erreichen!
Empfohlene Video-Tutorials: PHP-Einführungs-Tutorial
Lösung:
1. Serialisieren Sie die Zelldaten und speichern Sie sie im Speichermedium
PHPExcel_CachedObjectStorageFactory::cache_in_memory_serialized;
2. Serialisieren Sie die Zellen und komprimieren Sie sie dann mit Gzip. Speichern Sie sie dann im Speicher.
PHPExcel_CachedObjectStorageFactory::cache_in_memory_gzip;
3 kann langsamer sein
PHPExcel_CachedObjectStorageFactory::cache_to_discISAM;
4. Speichern Sie in php://temp
PHPExcel_CachedObjectStorageFactory::cache_to_phpTemp;
5. Speichern Sie im Memcache in
PHPExcel_CachedObjectStorageFactory::cache_to_memcache;
$cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_to_memcache; $cacheSettings = array( 'memcacheServer' => 'localhost', 'memcachePort' => 11211, 'cacheTime' => 600 ); PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings);
Beachten Sie, dass es vor new PHPExcel()
wie folgt eingefügt wird:
require_once APPPATH .'third_party/PHPExcel/PHPExcel.php'; $cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_to_phpTemp; $cacheSettings = array('memoryCacheSize'=>'16MB'); PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings); $objPHPExcel = new PHPExcel();
Empfohlene Tutorials zu verwandten Artikeln: PHP-Tutorial
Das obige ist der detaillierte Inhalt vonWelche Lösungen gibt es für den Speicherüberlauf beim Importieren großer Datenmengen in PHPExcel?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!