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 :

Optimisation de code


Sujet :

Python

  1. #1
    Membre confirmé
    Inscrit en
    Mars 2007
    Messages
    134
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 134
    Par défaut Optimisation de code
    Bonjour,

    je suis actuellement en train de développer un script très simple de conversion de format de donnée en Pyhton. Mon script marche bien mais comme il doit tourner intensivement, j'aimerais savoir si vous pouviez me donner des pistes pour le rendre le plus rapide possible.

    Il prend en entrée le contenu d'un fichier.

    Exemple de format d'entrée (fichier texte) :
    1.24 2.54 6.25 7.28
    2.98 2.19 0.38 0.01

    Et doit ressortir des listes de floats.

    Format de sortie attendue :
    [[1.24,2.54,6.25,7.28],[2.98,2.19,0.38,0.01]]

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    test = data.read().split("\n")[:-1] # Lecture du fichier ligne par ligne [['A B C D'],['E F G H']]
    dataList = map(lambda t: t.split(),test) # Sépare chaque élément
    nbData = len(dataList)
    store = []
    for i in range(nbData ):
        store.append(map(float, dataList[i])) # Pour chaque ligne, transforme chaque élément en float
    Merci d'avance pour votre aide.

  2. #2
    Membre Expert
    Homme Profil pro
    Inscrit en
    Mars 2007
    Messages
    941
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2007
    Messages : 941
    Par défaut
    Plus court, et sans doute plus rapide:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    store = [[float(e) for e in t.split()] for t in data]
    ou bien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    store = [map(float, t.split()) for t in data]

  3. #3
    Membre Expert

    Homme Profil pro
    Diverses et multiples
    Inscrit en
    Mai 2008
    Messages
    662
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Diverses et multiples

    Informations forums :
    Inscription : Mai 2008
    Messages : 662
    Par défaut
    Je ferais tout en une seule listcomprehension:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    store = [[float(f) for f in l.rstrip('\n').split()] for l in data]
    Ça évite à tout le moins la manipulation de variables intermédiaires…

    À noter, il semble que vous ayez besoin de vous débarrasser de la dernière ligne de votre texte, dans ce cas le code ci-dessus risque de ne pas fonctionner, il faudrait rajouter une fonction generator pour se débarrasser de cette dernière ligne, par exemple:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    def itf(f):
        prev_l = f.__next__()
        for l in f:
            yield prev_l
            prev_l = l
     
    store = [[float(f) for f in l.rstrip('\n').split()] for l in itf(data)]
    [Edit] Woops, grilled by dividee :p

  4. #4
    Membre confirmé
    Inscrit en
    Mars 2007
    Messages
    134
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 134
    Par défaut
    Merci beaucoup dividee et mont29.

    Les 2 solutions marchent très bien. Elles me semblent assez équivalentes en terme de vitesse d'exécution.

  5. #5
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 700
    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 700
    Par défaut
    Salut,

    Ne sachant trop ce que vous allez faire de ces "list"es de "float", ma réponse est peut être décalée. Mais si vous avez besoins de "performances", il faut sortir de Python et déléguer à numpy qui va se charger de remonter un tableau construit avec sa librarie C:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    import io
    import numpy as np
     
    TEXT = """1.24 2.54 6.25 7.28
    2.98 2.19 0.38 0.01"""
     
    f = io.StringIO(TEXT)
    a = np.loadtxt(f, delimiter=' ')
    for row in a:
        print (row)
    Bon courage
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  6. #6
    Membre confirmé
    Inscrit en
    Mars 2007
    Messages
    134
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 134
    Par défaut
    Merci wiztricks pour cette piste. Malheureusement, j'utilise ce code dans un environnement fermé et je ne peux pas installer d'application supplémentaire.

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

Discussions similaires

  1. optimiser le code d'une fonction
    Par yanis97 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 15/07/2005, 08h41
  2. Optimiser mon code ASP/HTML
    Par ahage4x4 dans le forum ASP
    Réponses: 7
    Dernier message: 30/05/2005, 10h29
  3. optimiser le code
    Par bibi2607 dans le forum ASP
    Réponses: 3
    Dernier message: 03/02/2005, 14h30
  4. syntaxe et optimisation de codes
    Par elitol dans le forum Langage SQL
    Réponses: 18
    Dernier message: 12/08/2004, 11h54
  5. optimisation du code et var globales
    Par tigrou2405 dans le forum ASP
    Réponses: 2
    Dernier message: 23/01/2004, 10h59

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