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 :

Syntaxe sur un "if not" multiple.


Sujet :

Python

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Chercheur
    Inscrit en
    Mars 2014
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mars 2014
    Messages : 14
    Points : 8
    Points
    8
    Par défaut Syntaxe sur un "if not" multiple.
    Hello.

    Je bloque sur une bétise, découvrant le python, je vous expose mon soucis.
    Je cherche a récuperer une liste de lien sur un site lambda (www.proute.com), sauf ceux dont le texte du dit lien comporte certains mots.
    Voici ma requête, avec un import mechanize plus haut.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    import mechanize
    br = mechanize.Browser()
     
    URL = "http://www.proute.com/"
    br.open(URL)
    BAN = ["img","Russian","french"]
     
     
    for link in br.links():
        if "http://www.proute.com/" in link.url:
            if BAN not in link.text:
                print "The name is : "+link.text
                print "the url is : "+link.url
    ça coince, j'ai ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
        if BAN not in link.text:
    TypeError: 'in <string>' requires string as left operand, not list
    Je dois avoir un soucis de syntaxe... je suis preneur de toute aide.
    Merci !

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    625
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 625
    Points : 822
    Points
    822
    Par défaut
    Hello,

    Le message d'erreur est explicite, tu peux pas chercher une liste dans une chaîne. Enfin pas aussi simplement.

    tu peux faire quelque chose du genre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    if not any([x in link.text for x in BAN]):
        ...blablabla...
    "[x in link.text for x in BAN]" retourne une liste attestant la présence de chaque élément de BAN dans link.text
    "any()" renvoie True si au moins un élément de la liste est True
    Pourfendeur de singletons en croisade

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Chercheur
    Inscrit en
    Mars 2014
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mars 2014
    Messages : 14
    Points : 8
    Points
    8
    Par défaut
    Oh mon dieu, fabuleux. ça marche, et c'est effectivement tout a fait logique
    Ben j'en apprend tout les jours, merci a toi !

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

Discussions similaires

  1. [MySQL] Syntaxe erreur apres avoir mis un quote '
    Par AyManoVic dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 12/07/2010, 16h50
  2. Réponses: 2
    Dernier message: 10/11/2009, 15h14
  3. ORA-01756: quoted string not properly terminated
    Par hottnikks_79 dans le forum SQL
    Réponses: 14
    Dernier message: 22/05/2007, 12h02

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