Heim  >  Artikel  >  Backend-Entwicklung  >  Welche Lösungen gibt es für den Speicherüberlauf beim Importieren großer Datenmengen in PHPExcel?

Welche Lösungen gibt es für den Speicherüberlauf beim Importieren großer Datenmengen in PHPExcel?

王林
王林Original
2019-12-02 10:22:254319Durchsuche

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn