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

王林
Freigeben: 2023-04-07 21:12:01
Original
4323 Leute haben es durchsucht

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;
Nach dem Login kopieren

2. Serialisieren Sie die Zellen und komprimieren Sie sie dann mit Gzip. Speichern Sie sie dann im Speicher.

PHPExcel_CachedObjectStorageFactory::cache_in_memory_gzip;
Nach dem Login kopieren

3 kann langsamer sein

PHPExcel_CachedObjectStorageFactory::cache_to_discISAM;
Nach dem Login kopieren

4. Speichern Sie in php://temp

PHPExcel_CachedObjectStorageFactory::cache_to_phpTemp;
Nach dem Login kopieren

5. Speichern Sie im Memcache in

PHPExcel_CachedObjectStorageFactory::cache_to_memcache;
Nach dem Login kopieren
$cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_to_memcache;  
$cacheSettings = array( 'memcacheServer'  => 'localhost',  
     'memcachePort'    => 11211,  
     'cacheTime'       => 600  
);  
PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings);
Nach dem Login kopieren

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();
Nach dem Login kopieren

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!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!