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 :

Python Profiler CPU mémoire


Sujet :

Python

  1. #1
    Membre habitué

    Profil pro
    Inscrit en
    Juin 2006
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 106
    Points : 182
    Points
    182
    Par défaut Python Profiler CPU mémoire
    Bonjour

    Venant du monde Java, j'utilise JProfiler pour profiler mes applis Java.
    Dans le cadre de mon travail, je viens de "récupérer" (à mon gd désespoir ) une grosse application en Python, avec du PyQt, Psi (Traits), etc..., bref bcp d'API que je ne connais pas du tout.
    Cette application est une "horreur" du point de vue performances CPU et utilisation mémoire, je recherche donc l'équivalent de JProfiler dans le monde Python pour savoir d'ou viennent ces pertes de perfo.
    J'ai l'impression que je n'ai pas trouvé gd chose pour analyser du code Python avec une interface graphique, si vous avez des pistes, je suis preneur.

    Merci

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

  3. #3
    Membre habitué

    Profil pro
    Inscrit en
    Juin 2006
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 106
    Points : 182
    Points
    182
    Par défaut
    Merci Sve@r

    J'avais déjà regardé les 2 premiers mais je voulais avoir un outil vraiment GUI friendly

    RQ : J'ai oublié de préciser que je travaillais sous Wxp

  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 691
    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 691
    Points : 30 988
    Points
    30 988
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par st20085 Voir le message
    Merci Sve@r

    J'avais déjà regardé les 2 premiers mais je voulais avoir un outil vraiment GUI friendly

    RQ : J'ai oublié de préciser que je travaillais sous Wxp
    Rien trouvé avec Gui.
    Mais j'ai trouvé ceci http://stackoverflow.com/questions/5...-python-script
    Assez simple à utiliser => suffit de taper en ligne de commande python -m cProfile tonAppli.py...
    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
    Expert éminent
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 465
    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 465
    Points : 9 257
    Points
    9 257
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Je n'utilise cProfile que de façon superficielle, mais ça me suffit la plupart du temps.

    Sous Windows, j'ai créé un fichier batch que j'appelle "profiler.bat", et qui contient:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    set nom=toto
    C:\Python27\python.exe -m cProfile -s time %nom%.py > %nom%.log
    "C:\Program Files (x86)\Notepad++\notepad++.exe" %nom%.log
    Je place ce fichier bat dans le répertoire de mon programme, et je l'édite pour mettre son nom sans l'extension (toto pour toto.py). La 1ère ligne devient donc: set nom=toto (pas d'espace de chaque côté du '=')

    On n'a pas besoin de lancer la console dos (cmd.exe): il suffit d'avoir le "windows explorer" et de double-cliquer sur le fichier profiler.bat. Le programme s'exécute en console, et, après son arrêt, le résultat du cProfile s'affiche dans l'éditeur de texte choisi (ici notepad++).

    Pour le résultat de cProfile, je demande le tri par temps décroissant (option -s time): j'ai donc les fonctions les plus lentes, donc à optimiser, au début.
    Un expert est une personne qui a fait toutes les erreurs qui peuvent être faites, dans un domaine étroit... (Niels Bohr)
    Mes recettes python: http://www.jpvweb.com

  6. #6
    Membre habitué

    Profil pro
    Inscrit en
    Juin 2006
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 106
    Points : 182
    Points
    182
    Par défaut
    Bonjour

    Désolé de ne répondre que maintenant, j'étais en congé.

    Merci Sve@r et tyrtamos, nous allons essayer votre solution puisque qu'à priori il n'existe pas de profiler plus évolué.

Discussions similaires

  1. python opencv consommation mémoire ?
    Par ddimi dans le forum Programmation multimédia/Jeux
    Réponses: 1
    Dernier message: 23/01/2011, 19h26
  2. Commandes pour charge disque / CPU / Mémoire
    Par arnaudperfect dans le forum Shell et commandes GNU
    Réponses: 7
    Dernier message: 26/07/2007, 21h35
  3. Réponses: 1
    Dernier message: 25/05/2007, 15h49
  4. Connaitre l'utilisation CPU/mémoire
    Par Flophx dans le forum Administration système
    Réponses: 5
    Dernier message: 09/02/2007, 11h40

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