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 :

Gestion de l ouverture d un fichier


Sujet :

Python

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2020
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2020
    Messages : 4
    Points : 5
    Points
    5
    Par défaut Gestion de l ouverture d un fichier
    Bonjour,

    Pour ouvrir un fichier CSV j ai utilisé la méthode suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    if not(os.path.isfile(fichier)):
            print ("pas trouvé")
        else:
            with open(fichier) as csvfile:
                ligne = csv.reader(csvfile, delimiter =",")
                for row in ligne:
                    if row[0] == blablablabla etc etc ....
    Ca marche tres tres bien, juste je me demande si :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    try:
            with open(fichier) as csvfile:
                ligne = csv.reader(csvfile, delimiter =",")
                for row in ligne:
                    if row[0] == blablablaetcetc ....:
                       ...
     
     
    except IOError:
            print ('pas trouvé)
    .... serait :
    -plus leger a traiter pas le systeme ? En effet avec la premiere methode j effectue 2 actions sur le disque, verifier sa présence pour ensuite l ouvrir(oui bon ok je sais que maintenant surtout avec l avenement des NVMe c est leger, mais sur quelques millions de requete ....)
    -plus rapide ?
    -plus élégant ?
    -stupide ? Tordu ? Déconnant ?

    Cela a l air de tourner aussi bien dans un cas ou dans l autre, mais si quelqu un a aussi une solution pour implementer la commande time sous windows je suis preneur aussi

    Merci d avance

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 283
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 283
    Points : 36 770
    Points
    36 770
    Par défaut
    Salut,

    Citation Envoyé par CaramelDur Voir le message
    -stupide ? Tordu ? Déconnant ?
    Vous allez un peu trop dans les détails.

    Si vous avez besoin de lire certaines lignes d'un fichier CSV, il est préférable de penser à créer une fonction nommée par exemple get_rows qui prenne le nom du fichier en paramètre et qui retourne les lignes sélectionnées.

    Une fois que la fonction "marche", vous allez pouvoir l'utiliser pour écrire le reste du code sans trop regarder ses instructions.

    Ce n'est que lorsque le programme fonctionne que vous allez vous posez des questions sur son optimisation (une fois que le code est "stable" et fonctionnel pas quand il est encore en chantier, c'est prématuré).

    Citation Envoyé par CaramelDur Voir le message
    mais si quelqu un a aussi une solution pour implementer la commande time sous windows je suis preneur aussi
    La bibliothèque datetime est "standard".

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2020
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2020
    Messages : 4
    Points : 5
    Points
    5
    Par défaut
    Re bonsoir,
    Tout d abord merci pour cette réponse .... pour le moins surprenante !
    En effet, ma question portait essentiellement sur ce que je nommerais "les bonnes pratiques" et/ou optimisation.... Navré si je me suis mal exprimé en ce sens.
    Mon code est bien fonctionnel et c est en repensant celui ci dans un but effectivement d optimisation que l idée de la seconde methode m est venue.
    Alors oui effectivement ce code tel que présenté n est pas fonctionnel puisqu il ne reflette qu une partie de mon travail, cette méthode de recherche au sein d un fichier csv étant bien inscrite au sein d une fonction, merci de bien vouloir considerer l idée, la methode, les deux fonctionnants très bien.
    Dans cette attente donc.
    Cordialement

  4. #4
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    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 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Bonsoir

    Je suis d'accord avec le try...except. D'autant plus que j'ai posé une question analogue il y a quelques temps et que ça a été la réponse privilégiée.

    Dans la première version il y a toujours un risque que le fichier soit modifié/perdu entre le test d'existence et l'ouverture concrète. La seconde version est la méthode assez souvent privilégiée. On se jette directement à l'eau et c'est seulement s'il n'y a pas d'eau que là on avise.
    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]

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2020
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2020
    Messages : 4
    Points : 5
    Points
    5
    Par défaut Merci
    Tres bon topic linké, un grand Merci a toi

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

Discussions similaires

  1. Gestion d'erreur à l'ouverture d'un fichier
    Par COCONUT2 dans le forum Général VBA
    Réponses: 6
    Dernier message: 20/01/2010, 21h47
  2. gestion de processus : ouverture fichier
    Par sam-sam dans le forum POSIX
    Réponses: 1
    Dernier message: 14/10/2007, 12h26
  3. Pb gestion erreur lors ouverture fichier excel
    Par titeelo dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 01/08/2007, 16h47
  4. Réponses: 5
    Dernier message: 27/07/2004, 17h04
  5. Réponses: 2
    Dernier message: 22/07/2002, 12h13

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