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 :

Cherche chaque valeur du fichier1 dans le fichier2 et affiche les ligne de fichier2 correspondantes


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Mai 2012
    Messages
    1
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2012
    Messages : 1
    Par défaut Cherche chaque valeur du fichier1 dans le fichier2 et affiche les ligne de fichier2 correspondantes
    Bonjour,

    J’ai un fichier 1 qui contient des codes d’identification sous forme:
    6271815
    1426282
    9726262
    5251161
    Et un fichier 2 qui contient :
    6271815 , Alexendre Legrand
    1426282 , Phillipe Dumas
    9726262 , Albert Einstein
    5251161, Nicolas Tesla
    1627286, Ben Aflek
    1522772, Richard Jean
    1272828, Céline Dion
    .......
    Je veux faire une recherche pour chaque valeur du fichier 1 dans le fichier 2 et si elle se trouve je fais imprimer la ligne du fichier 2 pour avoir le nom et le prénom et envoyer le tout dans fichier3.
    J’ai fait deux boucles For imbriquées mais il me manque un traitement de string que je n’arrive pas à retrouver, voilà mon code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    # -*- coding: utf-8 -*- 
     
    fichier_analyser = open("../fichier2.txt", "r+") 
    with open("../fichier1.txt", "r") as f: 
    for line in f: 
    for l in fichier_analyser: 
    if "line" in "l": 
    print(l)
    Toute aide est la bienvenue, je suis débutant avec python !
    Merci à vous tous,

  2. #2
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 833
    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 833
    Billets dans le blog
    1
    Par défaut
    Bonjour

    En écrivant if "line" in "l", tu cherches si la chaine littérale "line" se trouve dans la chaine littérale "l". Etre débutant n'excuse pas tout (et surtout n'excuse pas d'avoir la flemme d'ouvrir un tuto pour apprendre la différence entre string et variable).
    Ensuite tu dois prendre conscience que si une ligne vaut "6271815" alors elle contient en réalité "6271815\n" ce qui ne matchera pas "6271815 , Alexendre Legrand". Il faut utiliser str.strip() pour supprimer le "\n".
    Et question optimisation, tu pourrais stocker les valeurs du fichier1 ce qui t'éviterait de le relire à chaque fois et qui te permettra par exemple d'utiliser "in" (si par exemple tu stockes tous les codes dans un tuple "codes", alors en coupant "6271815 , Alexendre Legrand" sur la virgule (str.split()) tu obtiens "6271815" ce qui te permet d'utiliser alors if "6271815" in codes pour voir si le code de la ligne se trouve présent dans la liste des codes ce qui t'évite d'avoir à boucler manuellement dessus, mais bon cela suppose aussi un fichier au carat car avoir des lignes avec tantot code + virgule et tantot code + espace + virgule ça n'aide pas).
    Et bon les tabulations c'est quand tu veux.
    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]

Discussions similaires

  1. [XL-2007] VBA Chercher valeur de fichier1 dans fichier2
    Par yuva.iuva dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 13/08/2015, 13h50
  2. Réponses: 1
    Dernier message: 29/10/2014, 16h05
  3. Réponses: 2
    Dernier message: 09/04/2013, 11h06
  4. changer la valeur des données dans une colonne excel et les trier
    Par thewind1 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 28/01/2011, 22h35
  5. Réponses: 2
    Dernier message: 08/10/2010, 11h15

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