• Aucun résultat trouvé

TP9 : Manipulation de données en csv

N/A
N/A
Protected

Academic year: 2022

Partager "TP9 : Manipulation de données en csv"

Copied!
2
0
0

Texte intégral

(1)

TP9 : Manipulation de données en csv

Préléminaire

Sur le site internet, télécharger l’archiveTP9.zip.

La désarchiver pour obtenir les fichiers suivants :

• TP9.py, le fichier source que l’on va modifier au cours de la séance.

• series.csv, le fichier comportant les données sur les séries que l’on va manipuler.

• genres.csv, le fichier comportant les données des genres possibles.

• lien_genres_series.csv, le fichier comportant les numéros liant les séries et les genres enregistrés précé- demment.

• commentaires.csv, le fichier comportant les données des commentaires sur les différentes séries.

• dicoFrancais.py, le fichier qui met en place l’ordre alphabétique français. Ce fichier ne sera pas modifié seulement utilisé.

Exercice 1 : compréhension d’un csv

1. A l’aide d’un éditeur de texte (commeEmacspar exemple), ouvrer le fichier series.csv.

2. A l’aide delibre office, ouvrer le fichier series.csv. On sélectionnera « séparé par » puis « virgule ».

Cette deuxième ouverture permet une lecture plus facile des informations.

a. Identifier les différents critères enregistré sur chacune des séries.

b. En ouvrant de la même manière genres.csv et lien_genres_series.csv, identifier les genres de la série

« Sherlock ».

c. En ouvrant de la même manière commentaires.csv, déterminer le nombre de commentaires de la série

« Game of Thrones ».

Exercice 2 : automatisation de la lecture d’un csv 1. Ouvrir le fichierTP6.py avecIdle, puis exécuter le script :

print ( dict_series ())

Déterminer comment sont enregistrées les données des séries.

2. Maintenant, exécuter le script :

print ( retourner_le_titre_des_series ())

En comprendre les différentes lignes de la fonction utiliser.

3. Sur le même principe, écrire la fonction « retourner_le_titre_des_series_et_date() » qui affiche le message :

’le titre de la serie est "???" , elle existe depuis ??? ’

Les points d’interrogations seront remplacés par les informations du fichierseries.csv.

4. Sur le même principe, écrire la fonction « retourner_le_titre_des_series_et_date_en_production() » qui affiche le même message mais seulement avec les séries encore en cours de production.

Exercice 3 : mélanger plusieurs csv 1. Exécuter le script :

print ( retourner_le_numero_genre_d_une_serie (’7 ’ ))

Qu’affiche-t-il ?

2. Modifier la fonction pour obtenir uniquement les numéros de la série « Sherlock ».

3. Ecrire une fonction « dict_genres() » qui retourne la lecture du fichiergenres.csv en liste de dictionnaires.

4. Ecrire une fonction « retourner_le_genre_d_une_serie(IdSerie) » qui retourne le message :

’les genres sont ??? , ??? , ... ’

Les points d’interrogations seront remplacés par les genres dont le numéro aura été saisi.

1

(2)

Exercice 4 : l’écriture d’un csv

1. Nous allons utiliser la date et l’heure de l’ordinateur. Pour ceci rajouter le module suivant :

import datetime

2. Exécuter le script :

ecrire_commentaire ( ’ IdSerie ’ , ’ Note ’, ’ Pseudo ’, ’ Message ’ )

Comprendre cette fonction, on pourra changer les valeurs saisies.

3. Ecrire une fonction « nouveau_commentaire() » qui pose les différentes questions sur les données à saisir et exécute la fonction précédente avec les valeurs saisies.

4. Exécuter le script :

print ( retourner_commentaires_d_une_serie (’2 ’))

Modifier la fonction pour qu’elle affiche également l’année du commentaire.

Exercice 5 : pour aller plus loin

1. Un peu de tri, pour ceci on va ajouter les fonctions suivantes :

from operator import itemgetter from dicoFrancais import Compfr

Puis exécuter le script suivant :

print ( retourner_les_genres ())

Déterminer l’erreur produite. Pour la corriger, on va modifier le mode de triage par :

Genres . sort ( cmp = Compfr () , key = itemgetter ( ’ genre ’ ))

2. Ecrire une fonction qui calcule la moyenne des notes d’une série donnée ou qui retourne « Aucune note » s’il n’existe aucune note pour cette série.

3. Ecrire une fonction qui retourne le titre de cinq séries prises alétoirement parmi l’ensemble des séries (il faut que les titres soit tous distincts).

On utilisera la fonction suivante :

from random import randint

2

Références

Documents relatifs

(2) ´ Ecrire une fonction traitement qui prend pour arguments une image et une fonction puis applique cette fonction sur la valeur de chacun des pixels de l’image.. (3) Red´

Déterminer les trois formations/établissements qui ont le pourcentage le plus élevé d’admis néo bache- liers avec mention Très Bien au bac6. Déterminer les

Coloriez soigneusement les cases et les lignes afin d’aider Ozobot à se rendre de toute urgence à l’hôpital.. Il doit s'allumer en bleu pour montrer qu'il est

Téléversez le programme dans le robot Ozobot (suivre les étapes de l’aide en bas à gauche).. Posez le robot Ozobot sur l’emprunte et lancez le programme (voir l’aide en bas

´ Ecrire une fonction nombreDeUns d’argument un entier naturel n, qui renvoie le nombre de chiffres de 1 dans l’´ ecriture binaire de n.. Soit n un

Traitements pour la classification de textes Les données textuelles sont difficiles à gérer :.. 1 Les corpus sont volumineux, le vocabulaire est grand : - il faut des

Répondre au

Pour cela, on calcule les probabilités cumulées, cherchant la première valeur telle que la probabilité cumulée dépasse 2,5 %, puis la première valeur telle que la probabilité