Maison >interface Web >js tutoriel >Comment puis-je optimiser le temps de traitement des scripts Google Apps pour éviter les ralentissements ?

Comment puis-je optimiser le temps de traitement des scripts Google Apps pour éviter les ralentissements ?

Susan Sarandon
Susan Sarandonoriginal
2024-12-02 19:26:15832parcourir

How Can I Optimize Google Apps Script Processing Time to Avoid Slowdowns?

Optimisation 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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn