


Comment puis-je optimiser le temps de traitement des scripts Google Apps pour éviter les ralentissements ?
Dec 02, 2024 pm 07:26 PMOptimisation du temps de traitement dans les scripts Google Apps
Problème :
Temps de traitement excessif dans Google Scripts d'applications, notamment en raison de l'utilisation répétée des méthodes getValue et setValue pour range objets.
Description :
Pour réduire le nombre d'appels vers les serveurs de Google et minimiser l'alternance des opérations de lecture et d'écriture, pensez à utiliser les optimisations suivantes :
Réduire les appels aux services :
- Déplacer les opérations pouvant être effectuées dans Google Apps Script lui-même pour éviter des requêtes réseau coûteuses.
Anticipation de la mise en cache :
- Profitez du cache intégré de Google Apps Script en minimiser le nombre de lectures et d'écritures.
Réduire l'alternance Lecture/écriture :
- Évitez d'alterner les opérations de lecture et d'écriture, car cela entrave l'efficacité de la mise en cache anticipée.
Utiliser des tableaux :
- Lisez les données dans un tableau avec une seule commande et effectuez des opérations sur le tableau, puis écrivez le données vers la feuille avec une autre commande unique.
Exemple :
Voici un exemple de la façon d'optimiser le script fourni :
Script lent original :
for (row = 0; row < lastRow; row++) { range1 = s.getRange(row + 1, 1); cellValue = range1.getValue(); if (dash === '-' &amp;&amp; offset3) { s.getRange(row + 1, 1, lastRow).offset(3, 0).moveTo(range1.offset(4, 0)); }; }
Optimisé rapidement Script :
const lastRow = s.getRange("A:A").getLastRow(); const range1 = s.getRange(`A1:A${lastRow}`); let cellValues = range1.getValues(); cellValues.forEach((value, index) => { if (value.startsWith("-") &amp;&amp; cellValues[index + 3]) { range1.getRange(index + 1, 1, lastRow).moveTo(range1.offset(index + 4, 0)); } });
En mettant en œuvre ces optimisations, le script réduit considérablement le nombre d'appels aux services et rationalise les opérations de lecture/écriture, ce qui entraîne des temps de traitement plus rapides.
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!

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Remplacer les caractères de chaîne en javascript

jQuery obtient un rembourrage / marge d'élément

jQuery Vérifiez si la date est valide

10 vaut la peine de vérifier les plugins jQuery

Tutoriel de configuration de l'API de recherche Google personnalisé

Http débogage avec le nœud et le http-console

jQuery Ajouter une barre de défilement à div
