IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

APIs Google Discussion :

Script de mise en forme conditionnelle de plusieurs cellules selon une seule [Google Sheets]


Sujet :

APIs Google

  1. #1
    Membre régulier
    Inscrit en
    Septembre 2008
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Septembre 2008
    Messages : 11
    Par défaut Script de mise en forme conditionnelle de plusieurs cellules selon une seule
    Bonjour,

    je suis à la recherche d'un script qui me permettrai de réaliser une mise en forme conditionnelle.
    J'ai fait pas mal d'essais mais je n'y parvient pas. Le plus frustrant c'est qu'avec la mise en forme conditionnelle classique j'y arrive, mais ça me cause des soucis dès qu'il y a des copier/couper coller de cellule dans la feuille.

    Voila un résumé du besoin :
    Mon tableau contient pas mal de colonnes et bien entendu de lignes.
    Les cellules qui m'intéressent contiennent :

    ANNEE | N° SEMAINE | DATE DEBUT | DATE FIN

    La colonne 2 peut prendre plusieurs valeur :
    • soit un numéro de semaine
    • soit un numéro de semaine précédé d'un caractère p
    • soit le caractère i
    • soit être vide


    Je voudrais que lorsqu'une saisie est faite dans la colonne semaine, les 4 colonnes de la ligne changent de couleur selon la valeur saisie : n° semaine, ap, i ou p+n° semaine.

    Auriez-vous des pistes pour que je puisse avancer ?

    D'avance merci

    Cordialement

    Jean-François

  2. #2
    Membre régulier
    Inscrit en
    Septembre 2008
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Septembre 2008
    Messages : 11
    Par défaut
    Bonjour,

    après quelques recherches supplémentaires et essais hasardeux j'ai concocté quelque chose qui fait à peu prêt le boulot.

    Le défaut mais j'arrive pas à faire mieux c'est pour les conditions contenant seulement du texte (i et ap) où je n'arrive pas à colorier les 4 colonnes mais seulement celle contenant la valeur, il faut donc que je mette la valeur dans mes 4 colonnes.
    Ce n'est pas dramatique par rapport à mon besoin mais je n'arrive pas à faire mieux.

    Le soucis est que je n'arrive pas à faire comme pour les valeurs de numéro de semaine ou débutant par "p" à savoir une formule type "whenFormulaSatisfied" qui vérifierai que ma cellule contient soit le caractère "i" soit les caractère "ap".

    Si vous avez des idées je suis preneur.

    Pour ceux que ça brancherai voici le code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    var rangeS1 = sheet.getRange("H2:K900"); // Définir les colonnes
     var valuesS1 = rangeS1.getValues();
     
      // Si valeur = i --> Couleur vert
     var ruleS1I = SpreadsheetApp.newConditionalFormatRule()
         .whenTextEqualTo("i") // Définir la colonne servant de condition
         .setBackground("#00ff00")
         .setRanges([rangeS1])
         .build();
     
     var rulesS1I = sheet.getConditionalFormatRules();
     rulesS1I.push(ruleS1I);
     sheet.setConditionalFormatRules(rulesS1I);
     
        // Si valeur = ap--> Couleur rouge
     var ruleS1AP = SpreadsheetApp.newConditionalFormatRule()
         .whenTextEqualTo("ap") // Définir la colonne servant de condition
         .setBackground("#ff0000")
         .setRanges([rangeS1])
         .build();
     
     var rulesS1AP = sheet.getConditionalFormatRules();
     rulesS1AP.push(ruleS1AP);
     sheet.setConditionalFormatRules(rulesS1AP);
     
          // Si valeur commence par p --> Couleur jaune
     var ruleS1DP = SpreadsheetApp.newConditionalFormatRule()
         .whenFormulaSatisfied('=COUNTIF($I2;"p*")>0') // Définir la colonne servant de condition
         .setBackground("#ffff00")
         .setRanges([rangeS1])
         .build();
     
     var rulesS1DP = sheet.getConditionalFormatRules();
     rulesS1DP.push(ruleS1DP);
     sheet.setConditionalFormatRules(rulesS1DP);
     
      // Si valeur est numéro de semaine --> Couleur vert
     var ruleS1DF = SpreadsheetApp.newConditionalFormatRule()
         .whenFormulaSatisfied("=$I2<90") // Définir la colonne servant de condition
         .setBackground("#00ff00")
         .setRanges([rangeS1])
         .build();
     
     var rulesS1DF = sheet.getConditionalFormatRules();
     rulesS1DF.push(ruleS1DF);
     sheet.setConditionalFormatRules(rulesS1DF);

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 4
    Dernier message: 13/02/2017, 09h46
  2. Réponses: 5
    Dernier message: 29/11/2016, 17h24
  3. [XL-2010] Mise en forme conditionnelle sur plusieurs cellules
    Par bibi28 dans le forum Excel
    Réponses: 4
    Dernier message: 28/09/2016, 17h38
  4. Réponses: 6
    Dernier message: 15/06/2016, 17h47
  5. [XL-2007] mise en forme conditionnelle sur plusieurs feuilles
    Par electrons dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 09/01/2014, 10h40

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo