Optimisation des performances d'interopérabilité d'Excel
Introduction
L'automatisation d'Excel peut faire partie intégrante de nombreux candidatures. Cependant, il peut souvent présenter des goulots d'étranglement en termes de performances dans des scénarios impliquant des feuilles de calcul complexes. Cet article explore des techniques pratiques pour améliorer l'efficacité des appels interop Excel.
Appels intensifs en performances
Certains appels interop Excel ont un impact significatif sur les performances :
- Worksheet.Cells.Item(row, col) et Worksheet.Range récupèrent des valeurs ou des plages de cellules individuelles. Des appels excessifs à ces méthodes peuvent ralentir le traitement si vous accédez à de nombreuses cellules.
- L'écriture dans de grandes plages à l'aide de Range.Value2 peut être lente par rapport à l'écriture dans une plage plus petite, puis à la copie des résultats.
Améliorations des performances
Voici des techniques éprouvées pour améliorer l'interopérabilité d'Excel performances :
-
Désactiver les mises à jour de l'écran : Désactivez le redessinage de l'écran en définissant ExcelApp.ScreenUpdating = false pour empêcher les actualisations constantes de l'écran. Réactivez-le si nécessaire.
-
Suspendre les calculs : Désactivez les calculs à l'aide d'ExcelApp.Calculation = xlCalculationManual pour éviter le recalcul automatique d'Excel lors des modifications de valeur de cellule. Réinitialisez-le sur xlCalculationAutomatic une fois terminé.
-
Mise en cache des cellules : Réduisez les appels à Worksheet.Cells.Item(row, col) en mettant en cache les emplacements des cellules pour un accès plus rapide. Cette optimisation peut réduire considérablement le temps d'exécution.
-
Accès à la plage par lots : Lors de la modification de grandes plages, il est plus efficace de récupérer la plage entière à l'aide de Range.Value2, puis de manipuler les valeurs en mémoire.
-
Écriture efficace dans les plages : Réduisez la taille des plages écrites en utilisant Range.Value2 sur des plages plus petites, puis copier les résultats dans une plage plus large.
Considérations supplémentaires
- Assurez-vous que les types de données sont convertis correctement lors de l'accès aux valeurs du tableau object[,] renvoyé à partir de Range.Value2.
- Évitez les étapes de traitement inutiles, telles que des boucles excessives ou calculs.
- Envisagez le multithreading pour paralléliser les tâches et améliorer les performances.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!