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

Python Discussion :

trouver mot dans chaîne de caractère [Python 3.X]


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Homme Profil pro
    responsable d'institut métier
    Inscrit en
    Octobre 2020
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : responsable d'institut métier
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2020
    Messages : 5
    Par défaut trouver mot dans chaîne de caractère
    Bonjour,

    je fais une mise en forme sur un fichier google sheet en fonction de ce que contient une cellule, si il y a le mot module dans la première cellule, tu me met la ligne en forme.

    voici mon 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
    for v, r in zip(values, range(5, 57)):
        if "Module" in v:
            year1.format(
                f"A{r}:C{r}",
                {
                    "backgroundColor": {"red": 0.4, "green": 0.4, "blue": 0.4},
                    "textFormat": {
                        "foregroundColor": {"red": 0.95, "green": 0.95, "blue": 0.95},
                        "fontFamily": "Economica",
                        "fontSize": 14,
                        "bold": True,
                    },
                },
            )
    values c'est les valeurs de la première colonne, ce qui m'intrigue c'est qu'il ne met en forme que quand il y a "Module", si il y a "Module 1" il ne le prend pas en compte. Pourtant le booléen est bien en True sur les cellules qui contiennent "Module plus quelque chose"...

    Je ne comprend pas.....

    merci par avance

  2. #2
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Suggestions:

    - ajouter un print(v) sous le "if" pour vérifier

    - quel est le traitement sous le "if"? (year1?)

  3. #3
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 835
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 835
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par mthgn Voir le message
    si il y a "Module 1" il ne le prend pas en compte.
    Je ne comprend pas.....
    Déjà premier test...
    Code Python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    >>> "Module" in "Module 1"
    True
    ... et on constate que ça fonctionne. Donc Python n'est pas en cause. Donc il faut admettre que ce sont les valeurs qui sont en cause et que quand tu crois qu'il y a "Module 1" en fait il y a autre chose.

    Donc seconde étape: rajouter juste avant le "if" print("[%s]" % v, type(v), "Module" in v) pour voir concrètement ce qui se passe. Ce qui rejoint et complète la suggestion de tyrtamos.

    Ensuite que se passe-t-il s'il y a plus de 52 valeurs dans values? zip(values, range(5, 57)) s'arrête au plus petit des deux donc peut-être que tu ne traites pas tout ce qu'il y a dans values => remplacer par for (r, v) in enumerate(values, 5)....
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    responsable d'institut métier
    Inscrit en
    Octobre 2020
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : responsable d'institut métier
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2020
    Messages : 5
    Par défaut
    Merci pour votre aide!

    en fait le get() de gspread renvoie une liste de listes contenant chacune un mot, forcément ça pouvait pas marcher...

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

Discussions similaires

  1. [LibreOffice][Tableur] Recherche mot dans chaîne de caractères
    Par ludovik49 dans le forum OpenOffice & LibreOffice
    Réponses: 4
    Dernier message: 04/10/2014, 17h09
  2. [WD-2003] Trouver mot dans chaine de caractères >résultat
    Par QuestVba dans le forum VBA Word
    Réponses: 2
    Dernier message: 03/12/2012, 13h10
  3. Isoler caractères dans chaîne de caractères
    Par neige2027 dans le forum VBA Access
    Réponses: 4
    Dernier message: 21/08/2009, 09h19
  4. Trouver mot dans une variable
    Par Jeyjey1 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 18/04/2008, 17h21
  5. nombre de répétitions dans chaînes de caractères
    Par jocarina dans le forum Langage SQL
    Réponses: 10
    Dernier message: 20/06/2005, 13h07

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