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 : fichier


Sujet :

Python

  1. #1
    Membre habitué
    Femme Profil pro
    Lycéen
    Inscrit en
    Novembre 2019
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Lycéen

    Informations forums :
    Inscription : Novembre 2019
    Messages : 12
    Par défaut Python : fichier
    BONJOUR

    Écrire une fonction wc(nomFichier) qui ouvre le fichier en question et renvoie un tuple de trois nombres :

    le nombre de caractères (y compris les caractères de retour à la ligne)

    le nombre de mots

    le nombre de lignes


    CONSIGNE

    Nous définissons ici un mot comme étant une chaîne de caractères alphanumériques, c’est-à-dire répondant True à la méthode isalnum(), et maximale, c’est-à-dire entourée d’espaces ou de séparateurs ou de caractères de fin de phrase.

    Les fichiers utilisés par UpyLaB pour tester la fonction sont accessibles aux adresses suivantes :

    https://upylab.ulb.ac.be/pub/data/wc1.txt

    https://upylab.ulb.ac.be/pub/data/Zola.txt

    https://upylab.ulb.ac.be/pub/data/le-petit-prince.txt

    Pour information, le premier fichier contient les caractères a2x!§t5\n (\n désignant le caractère de fin de ligne). L’appel de la fonction sur ce fichier retourne donc le tuple (8, 2, 1), les deux mots étant a2x et t5.

    Notez que le fichier le-petit-prince.txt est libre de droit d’auteur sauf en France (voir https://fr.wikipedia.org/wiki/Le_Petit_Prince). Si vous habitez en France, vous ne pouvez donc légalement le télécharger, mais aucun souci ailleurs dans le monde.

    Vous pourriez être tenté d’utiliser la méthode split. Ce n’est peut-être pas une très bonne idée, car la liste des séparateurs est ici très longue. Par exemple, le fichier pourrait contenir la chaîne

    "a$€αω$BOjJOurα"
    Nous définissons ici un mot comme étant une chaîne de caractères alphanumériques, c’est-à-dire répondant True à la méthode isalnum(), et maximale, c’est-à-dire entourée d’espaces ou de séparateurs ou de caractères de fin de phrase.

    Les fichiers utilisés par UpyLaB pour tester la fonction sont accessibles aux adresses suivantes :

    https://upylab.ulb.ac.be/pub/data/wc1.txt

    https://upylab.ulb.ac.be/pub/data/Zola.txt

    https://upylab.ulb.ac.be/pub/data/le-petit-prince.txt

    Pour information, le premier fichier contient les caractères a2x!§t5\n (\n désignant le caractère de fin de ligne). L’appel de la fonction sur ce fichier retourne donc le tuple (8, 2, 1), les deux mots étant a2x et t5.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    def wc(nomFichier):
     
        with open("/pub/data/wc1.txt",'r') as file:  
            contenu = file.read()  
            longueur = len()  
            nb_mots = 2
            nb_lignes = 1
            return longueur, nb_mot, nb_lignes

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

    Vous avez lu l'énoncé:
    Nous définissons ici un mot comme étant une chaîne de caractères alphanumériques, c’est-à-dire répondant True à la méthode isalnum(), et maximale, c’est-à-dire entourée d’espaces ou de séparateurs ou de caractères de fin de phrase.
    Vous savez ce que doit retourner votre fonction pour le premier fichier:
    Pour information, le premier fichier contient les caractères a2x!§t5\n (\n désignant le caractère de fin de ligne). L’appel de la fonction sur ce fichier retourne donc le tuple (8, 2, 1), les deux mots étant a2x et t5.
    Donc vous savez tester votre fonction et vérifier par vous même si le résultat est attendu ou pas.

    Après, si votre code ne fonctionne pas, pour avoir de l'aide, il faut faire des phrases pour expliquer ce que vous avez cherché à faire pour... et pourquoi vous ne comprenez pas que çà ne le fasse pas i.e. que vous avez essayé de comprendre le problème et comment écrire la solution.

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

  3. #3
    Membre habitué
    Femme Profil pro
    Lycéen
    Inscrit en
    Novembre 2019
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Lycéen

    Informations forums :
    Inscription : Novembre 2019
    Messages : 12
    Par défaut
    Bah je voulais juste savoir comment je fait pour les deux autres car j'ai essayer un autre with mais ça ne fonctionne pas

  4. #4
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 715
    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 715
    Par défaut
    Citation Envoyé par Prada1020 Voir le message
    Bah je voulais juste savoir comment je fait pour les deux autres car j'ai essayer un autre with mais ça ne fonctionne pas
    Pour l'instant, vous proposez une solution au premier exercice qui montre que vous n'avez pas lu l'énoncé ni testé le code que vous proposez.
    Et si votre code ne fonctionne pas pour le premier fichier pas la peine de regarder les fichiers suivants.

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

  5. #5
    Membre habitué
    Femme Profil pro
    Lycéen
    Inscrit en
    Novembre 2019
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Lycéen

    Informations forums :
    Inscription : Novembre 2019
    Messages : 12
    Par défaut
    détromper vous il fonctionne pour le premier fichier :
    Bon résultat pour wc('/pub/data/wc1.txt') : (8, 2, 1)

  6. #6
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 715
    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 715
    Par défaut
    Citation Envoyé par Prada1020 Voir le message
    détromper vous il fonctionne pour le premier fichier :
    Vous avez modifié votre code pour que ce que çà retourne ressemble un peu à ce qui est demandé.
    Ceci dit vous avez écrit à la ligne 5: longueur = len() qui plante...
    Donc votre fonction ne retourne rien.

    Donc plutôt que d'essayer de me prendre pour une bille, montrez que vous savez faire quelque chose avec Python plutôt qu'attendre qu'on fasse votre boulot/exercice.

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

  7. #7
    Membre habitué
    Femme Profil pro
    Lycéen
    Inscrit en
    Novembre 2019
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Lycéen

    Informations forums :
    Inscription : Novembre 2019
    Messages : 12
    Par défaut
    Vous êtes tous aussi agressive ici ? ou quoi ? je veux juste de l'aide si vous me croyait pas regarder par vous mm
    Ahh non non mais j'ai fait une erreurs en postant le code sur forum c
    len(contenu)
    et non
    len()

    Nom : za.JPG
Affichages : 1458
Taille : 78,4 Ko

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

    Citation Envoyé par Prada1020 Voir le message
    Vous êtes tous aussi agressive ici ? ou quoi ? je veux juste de l'aide si vous me croyait pas regarder par vous mm
    Ahh non non mais j'ai fait une erreurs en postant le code sur forum c et non
    Ben, il faut s'appliquer un peu, se relire,.... en plus vous savez éditer vos messages.

    Pour le reste, voilà votre code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    def wc(nomFichier):
     
        with open("/pub/data/wc1.txt",'r') as file:  
            contenu = file.read()  
            longueur = len()  
            nb_mots = 2
            nb_lignes = 1
            return longueur, nb_mot, nb_lignes
    Il n'essaie même pas de compter les mots du fichier.
    Alors passez un peu de temps à réfléchir et à coder quelque chose qui ressemble à ce qu'on vous demande.
    Si vous rencontrez des difficultés, vous les exposez et vous aurez peut être de l'aide.

    Et si vous n'avez pas envie de bosser, assumez! Et plutôt que de faire faire le boulot par d'autres, attendez le corrigé que vous donnera le professeur.

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

  9. #9
    Membre habitué
    Femme Profil pro
    Lycéen
    Inscrit en
    Novembre 2019
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Lycéen

    Informations forums :
    Inscription : Novembre 2019
    Messages : 12
    Par défaut
    bon oublions le sujet ct une mauvaise idée de poster le sujet ...
    j'aimerais juste savoirs comment ajouter d'autres fichiers dans ma fonctions ,c'est possible ?

  10. #10
    Membre Expert
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    2 910
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 2 910
    Par défaut
    Salut,

    Je pense que ce fil pourrait vous intéresser : Compter le nombre d’occurrences de chaque mot d'un texte

  11. #11
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 715
    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 715
    Par défaut
    Citation Envoyé par Prada1020 Voir le message
    bon oublions le sujet ct une mauvaise idée de poster le sujet ...
    Pour Python, un fichier, c'est d'abord une chaîne de caractères (le nom du fichier).
    Si vous voulez appliquer la même fonction f au chaînes de caractères A, B, C... çà se fait avec une boucle:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    for z in (A, B, C):
         f(z)
    Et si vous voulez compter les mots qu'il y a dans le fichier, çà se fait aussi avec une boucle dans laquelle vous allez devoir utiliser la méthode .isalnum.

    Citation Envoyé par Beginner. Voir le message
    Je pense que ce fil pourrait vous intéresser : Compter le nombre d’occurrences de chaque mot d'un texte
    Ca serait bien de lire l'énoncé du problème avant de suggérer quoi que ce soit.

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

  12. #12
    Membre Expert
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    2 910
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 2 910
    Par défaut
    Citation Envoyé par wiztricks Voir le message
    Ca serait bien de lire l'énoncé du problème avant de suggérer quoi que ce soit.
    J'avais bien lu l’énoncé et j'avais rédigé une réponse expliquant en quoi ma réponse pouvait intéresser la personne et il me semblait bien l'avoir postée mais là je ne la vois plus... Je ne sais ce qui s'est passé...

    Bon tant pis... Je t'ai répondu en privé...

  13. #13
    Membre habitué
    Femme Profil pro
    Lycéen
    Inscrit en
    Novembre 2019
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Lycéen

    Informations forums :
    Inscription : Novembre 2019
    Messages : 12
    Par défaut
    Okay mercii comment tu as fait pour être modo ??

    j'ai mis :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
                   nb_mots= contenu.isalnum()
                   nb_lignes= contenu.split()
    coup de pouce ?

  14. #14
    Membre Expert
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    2 910
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 2 910
    Par défaut
    Citation Envoyé par Prada1020 Voir le message
    j'ai mis : nb_mots= contenu.isalnum()
    nb_lignes= contenu.split()

    coup pouce ?
    J'avais expliqué dans un message disparu qu'on pouvait utiliser la fonction utilisée au message 3 : re.findall

    La fonction re.split est à éviter car dans l'énoncé il est dit ceci :

    Vous pourriez être tenté d’utiliser la méthode split. Ce n’est peut-être pas une très bonne idée, car la liste des séparateurs est ici très longue. Par exemple, le fichier pourrait contenir la chaîne
    En utilisant la regex adaptée* avec la méthode re.findall on n'a pas le problème évoqué (liste des séparateurs très longue)...

    Avec cette méthode pas besoin de la fonction isalnum alors la question qui s'est posée c'est : est-ce que l'usage de la fonction isalnum vous est imposée on non ?

    Avant de continuer il faudrait avoir la réponse à cette question...


    * j'ai testé ça : mots = re.findall(r'[a-zA-Z0-9]+', line)

  15. #15
    Expert confirmé Avatar de papajoker
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2013
    Messages
    2 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nièvre (Bourgogne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2013
    Messages : 2 322
    Par défaut
    Citation Envoyé par Prada1020 Voir le message
    j'ai mis : nb_mots= contenu.isalnum()
    nb_lignes= contenu.split()

    coup pouce ?
    Tu te fiches de nous ?
    Comment peut-tu écrire ceci ? ton code est à la limite encore pire que ton premier jet ! ici on peut voir que tu n'as meme pas pris le temps de lire la documentation et nous nous devons prendre le temps de t'aider
    chaine.split retourne quoi si tu te donnes la peine de lire la doc ? pas mieux pour isalnum qui retourne un boolean (je ne parles pas de ce que font ces fonctions, tu n'en as aucune idée non plus)

    On te demande d'écrire un algorithme : c'est donc un certain nombre de lignes qui viennent de ton analyse et pas de copier/coller une fonction au hazard qui va faire par magie tout ton travail

    - une comparaison par rapport à un cours de français : le prof te demande une rédaction et tu rends un seul mot, ici c'est exactement ce que tu fais
    - si on te demande ton age : tu ne vas pas répondre juste "soustraction" mais bien année courante - année de ta naissance

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

    Citation Envoyé par Prada1020 Voir le message
    coup de pouce ?
    Lancez l'interpréteur Python et essayez de comprendre:
    Je récupère le contenu du premier fichier:
    puis j'écris une boucle qui teste isalnum ou pas:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    >>> for c in s:
    ...     print (c, c.isalnum())
    ...
    a True
    2 True
    x True
    ! False
    § False
    t True
    5 True
     
     False
    >>>
    Les True consécutifs définissent un mot puisque "entourée d’espaces ou de séparateurs ou de caractères de fin de phrase".
    Et si on compte les séquences de True, on en a bien 2.
    Donc compter les mots se ramène à compter "intelligement" les transitions de True à False.
    Puisqu'il s'agit de transitions, il va falloir comparer isalnum du caractère courant avec celui du caractère précédent.
    Ca donne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    >>> s = 'a2x!§t5\n'
    >>> last = s[0].isalnum()
    >>> count = 1
    >>> for c in s:
    ...      current = c.isalnum()
    ...      if current and not last:
    ...            count += 1
    ...      last = current
    ...
    >>> print(count)
    2
    >>>
    C'est pas compliqué...

    Une fois compris cela, il va falloir améliorer le code pour calculer la valeur initiale de "count" (qui dépend de s[0].isalnum()).
    Puis vous pouvez ajouter un compteur pour compter les lignes, un autre pour compter les caractères.

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

  17. #17
    Expert confirmé Avatar de papajoker
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2013
    Messages
    2 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nièvre (Bourgogne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2013
    Messages : 2 322
    Par défaut
    pas fan de débuter l'état par le caractère 0, (pas dans les exemples mais ) si le premier caractère est un séparateur (indentation d'un paragraphe) alors on a un mot de plus ` a2x!§t5\n`
    Pour les noms de variables ... je trouve cela un peu brut pour les débutants
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    texte = ' a2x!§t5\n'
    nb_mots = 0
    etait_un_separateur = True
    for char in texte:
        est_un_separateur = not char.isalnum()
        if not est_un_separateur and etait_un_separateur :
            nb_mots +=1
        etait_un_separateur = est_un_separateur
        print(" ",char, nb_mots, est_un_separateur)
    print(nb_mots, "mots dans le texte")

  18. #18
    Membre Expert
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    2 910
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 2 910
    Par défaut
    Salut,

    Moi j'avais fait ça :
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    def analyse_fichier(nomfichier):
     
        with open(nomfichier, 'r') as file:
     
            nbr_caracteres = 0
            nbr_mots = 0
            nbr_lines = 0
            is_precedentchar_alnum = None
            word = ""
            list_words = []
     
            content = file.read()
            if content == "":
                return ": Fichier vide..."
            # nbr_caracteres = len(content) # peut-être que c'est mieux que de faire plusieurs incrémentions dans la boucle ci-dessous : "nbr_caracteres += 1" ???
            for char in content:
                nbr_caracteres += 1
                is_currentchar_alnum = char.isalnum()
     
                if is_currentchar_alnum:
                    word += char
                else:
                    if is_precedentchar_alnum:  # if not is_currentchar_alnum and is_precedentchar_alnum
                        nbr_mots += 1
                        list_words.append(word)
                        word = ""
                    if char == "\n":  # if not is_currentchar_alnum and char == "\n"
                        nbr_lines += 1
     
                is_precedentchar_alnum = is_currentchar_alnum
     
            if word != '':
                list_words.append(word)
                nbr_mots += 1
     
        return nbr_caracteres, nbr_mots, nbr_lines, list_words
     
     
    path = "chemin du fichier"
    with open(path + "wc1.txt", 'w') as file:
        file.write('a2x!§t5\n')
     
     
    resultat = analyse_fichier(path + "wc1.txt")
    print("\n---> résultat pour le fichier wc1.txt", resultat, "\n")

    C'est vrai que c'est moins simple à comprendre...

    J'ai ajouté la liste des mots ce qui complique le code...

    Cela m’embête d'avoir dû ajouter cette partie-là :
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if word != '':
                list_words.append(word)
                nbr_mots += 1
    Je ne sais pas si on peut l'éviter...

  19. #19
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 715
    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 715
    Par défaut
    Citation Envoyé par papajoker Voir le message
    pas fan de débuter l'état par le caractère 0, (pas dans les exemples mais ) si le premier caractère est un séparateur (indentation d'un paragraphe) alors on a un mot de plus ` a2x!§t5\n`
    Ca c'est un bug: d'un côté, je dis compter "les transitions de True à False." et dans mon code la condition est "current and not last".

    Ok, çà semble repousser le problème à la fin de la chaîne de caractères (le comptage du dernier mot)... mais soit on dit que le fichier texte est bien construit (et toutes les lignes doivent se terminer par '\n') soit on ajoute inconditionnellement un '\n' à la chaîne de caractères à compter et çà le fait très bien.

    Citation Envoyé par papajoker Voir le message
    Pour les noms de variables ... je trouve cela un peu brut pour les débutants
    Ce qui pourrait être dur pour les débutants c'est "for c in s:" à la place d'un "for i in range(len(s)):"

    Pour les noms de variables, dans les années 80s probablement.
    Aujourd'hui, à peu près tout le monde (et surtout les jeunes) a appris à subir/cohabiter avec un jargon aux accents outre atlantique.
    Moi, çà me va bien car fabriquer des noms de variables avec la langue de Molière rend le code plus difficile à lire: on veut être précis et on se retrouve à lire le texte plutôt que le code. Avec du globish, on a moins cet inconvénient.

    Ceci dit quand je lis:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    texte = ' a2x!§t5\n'
    nb_mots = 0
    etait_un_separateur = True
    for char in texte:
        est_un_separateur = not char.isalnum()
        if not est_un_separateur and etait_un_separateur :
            nb_mots +=1
        etait_un_separateur = est_un_separateur
        print(" ",char, nb_mots, est_un_separateur)
    print(nb_mots, "mots dans le texte")
    mais si on reformule le problème initial au comptage des transitions de True à False, il n'y a plus de séparateur!.
    Mais on peut discuter sans fin sur le nommage des variables!
    Dernière mouture:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    last = False
    count = 0
    for i in range(len(s)):
        current = s[i].isalnum()
        if current and not last:
            count += 1
        last = current
    print(count)
    Ce qui est la même chose sauf que la logique est inversée.

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

  20. #20
    Futur Membre du Club Avatar de le237sims
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2018
    Messages : 4
    Par défaut
    je ne sais pas si mon code aide mais le voila il valide le test. Mais j'aimerais avoir vos avis sur ce dernier

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
     
    def wc(fichier ): 
        mot=0
        for i in range (3):
            if i==0:
                f = open(fichier, encoding="UTF-8")
                caract=len(f.read())
            elif i==2: 
                f = open(fichier, encoding="UTF-8")
                ligne=len(f.readlines())
            elif i ==1:
                for l in open(fichier , encoding="UTF-8"):
                    for j in range(len(l)):
                        if   l[j].isalnum()==True and (l[j-1].isalnum()==False or l[j-1]==l[len(l)-1]):
                            mot+=1            
        t=[ caract,mot,ligne ]
        f.close()
        return(tuple(t))

Discussions similaires

  1. Exemple Webservice Python + fichier WSDL
    Par Enthau dans le forum Interfaçage autre langage
    Réponses: 1
    Dernier message: 26/05/2017, 16h52
  2. Python + fichiers Root + SetUid
    Par zesamoth dans le forum Général Python
    Réponses: 1
    Dernier message: 16/05/2007, 20h43
  3. Réponses: 2
    Dernier message: 19/12/2005, 13h15
  4. [swig] python->C->python, pointeur de fichier
    Par PyBio dans le forum Interfaçage autre langage
    Réponses: 1
    Dernier message: 10/11/2005, 15h50
  5. Les 128 derniers bits d'un fichier en ligne avec Python ?
    Par ecocentric dans le forum Réseau/Web
    Réponses: 7
    Dernier message: 26/09/2005, 12h40

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