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 :

Trier par ordre décroissant les caractères à partir d'un texte


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2018
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 26
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2018
    Messages : 1
    Par défaut Trier par ordre décroissant les caractères à partir d'un texte
    Bonjour,

    Je suis en train de construire un projet (analyse linguistique de textes politiques avec Python). Je suis bloquée à une étape... La consigne : classer par ordre d'utilisation décroissante chaque caractère et son nombre d'utilisation.

    Mon code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    import os
    fichier=open("Bayrou.txt","r")
    a=fichier.read()
    print("Nombre d'apparition des caractères : ")
    a=a.lower()
    for car in "abcdefghijklmnopqrstuvwxyz":
        print(car," : ",a.count(car))

    Il m'affiche bien le nombre de chaque lettre dans le discours (a : 3090, b : 465, ect..), mais impossible de trier ce qui sort (en conséquent le nombre) par ordre décroissant. Une idée ?

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

    Citation Envoyé par Pluume Voir le message
    Il m'affiche bien le nombre de chaque lettre dans le discours (a : 3090, b : 465, ect..), mais impossible de trier ce qui sort (en conséquent le nombre) par ordre décroissant. Une idée ?
    Pour trier, il faut pouvoir comparer l’occurrence des différentes lettres.
    Et pour "comparer", il va falloir stocker l'information (lettre, occurrence) dans une liste ou un dictionnaire puis lui appliquer une fonction de tri (à écrire, si c'est le but de l'exercice ou en utilisant "sorted").

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

  3. #3
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    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 486
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Voilà une solution possible en utilisant un dictionnaire pour la saisie, et une "liste de listes" pour les résultats triés:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    a = "Que j'aime à faire apprendre ce nombre utile aux sages"
    d = dict()
    for car in a:
        if car not in d:
            d[car] = a.count(car)
    print(d)         
     
    d2 = sorted(d.items(), key=lambda v: v[1], reverse=True)
    print(d2)
    [(' ', 9), ('e', 9), ('a', 5), ('r', 4), ('i', 3), ('u', 3), ('n', 2), ('p', 2), ('s', 2), ('m', 2), ('o', 1), ('b', 1), ('x', 1), ('d', 1), ('t', 1), ('j', 1), ('f', 1), ('à', 1), ('g', 1), ('Q', 1), ('c', 1), ("'", 1), ('l', 1)]
    Les dictionnaires sont une bonne structure pour les accès rapides, mais il ne gardent pas l'ordre de création des clés, et ne se trient pas. Par contre, le module "collections" possède un dictionnaire "ordonné" qui conserve l'ordre de création des clés. Selon l'utilisation qu'on a après, on peut convertir facilement la liste de listes en dictionnaire ordonné:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    from collections import OrderedDict
     
    d3 = OrderedDict(d2)
    print(d3)
    OrderedDict([(' ', 9), ('e', 9), ('a', 5), ('r', 4), ('i', 3), ('u', 3), ('n', 2), ('p', 2), ('s', 2), ('m', 2), ('o', 1), ('b', 1), ('x', 1), ('d', 1), ('t', 1), ('j', 1), ('f', 1), ('à', 1), ('g', 1), ('Q', 1), ('c', 1), ("'", 1), ('l', 1)])
    On pourra après questionner facilement les résultats obtenus:


  4. #4
    Expert confirmé
    Avatar de fred1599
    Homme Profil pro
    Lead Dev Python
    Inscrit en
    Juillet 2006
    Messages
    4 079
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Lead Dev Python
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4 079
    Par défaut
    Sans oublier le fameux Counter hyper efficace pour compter le nombre d'occurrences.

Discussions similaires

  1. Réponses: 2
    Dernier message: 17/07/2017, 16h02
  2. Comment trier en ordre décroissant les valeurs >0
    Par karima123 dans le forum Excel
    Réponses: 4
    Dernier message: 11/08/2016, 16h18
  3. [XL-2010] Trier en ordre décroissant les données d'un tableau
    Par guitalex dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 12/04/2014, 01h20
  4. [MySQL] Trier par ordre décroissant
    Par notour dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 09/08/2007, 09h06
  5. Trier les données dans 1 tableau par ordre décroissant
    Par Blunet dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 23/11/2005, 09h56

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