Une table est une structure de données organisée en lignes et colonnes. Un fichier CSV (Comma-Separated Values) stocke des données tabulaires sous forme de texte, avec les valeurs séparées par des virgules.
L'importation de CSV permet de charger ces données dans un programme pour les analyser ou les manipuler facilement.
En programmation, une liste de listes est une structure de données qui permet de stocker des éléments sous forme de tableaux à plusieurs dimensions. Chaque élément de la liste principale est en fait une liste elle-même.
Création d'une Liste de Listes
Pour créer une liste de listes en Python, vous pouvez simplement imbriquer des listes. Chaque sous-liste représente une rangée ou une dimension.
liste_de_listes = [
[1, 2, 3],
[4, 5, 6],
[7, 8, 9]
]
Accéder aux Éléments
Vous pouvez accéder aux éléments d'une liste de listes en utilisant des indices multiples. Utilisez d'abord l'indice de la sous-liste, puis l'indice de l'élément à l'intérieur de la sous-liste.
element = liste_de_listes[1][2] # Accès à la deuxième sous-liste, troisième élément
Modification d'Éléments
Vous pouvez également modifier les éléments de la liste de listes de la même manière qu'un tableau à une dimension.
liste_de_listes[0][1] = 99 # Modification du deuxième élément de la première sous-liste
Parcourir une Liste de Listes
Utilisez des boucles imbriquées pour parcourir tous les éléments d'une liste de listes.
for sous_liste in liste_de_listes:
for element in sous_liste:
print(element)
Stockez ce tableau sous forme d’une liste de listes nommée personnes
en Python.
Nom | Prénom | Âge |
---|---|---|
Durand | Jean | 32 |
Vignu | Mauricette | 89 |
Vignu | Capucine | 9 |
Vander | Louise | 17 |
Tests :
# Tests
Affichage :
Console:
Écrivez une fonction est_present
qui prend en entrée une liste de listes de caractères ainsi qu’un caractère. La fonction doit renvoyer True
si ce caractère est présent, et False
sinon.
Par exemple, avec la liste ci-dessous :
alphabet_listes = [
['D', 'B', 'C'],
['F', 'A', 'E'],
['H', 'G', 'I']
]
On doit obtenir :
>>> est_present(alphabet_listes,'E')
True
>>> est_present(alphabet_listes,"Z")
False
Tests :
# Tests
Affichage :
Console:
Compléter une fonction somme_des_sous_listes
prenant comme paramètre une liste de listes de nombres et renvoyant une nouvelle liste contenant la somme de chaque sous-liste.
Exemple attendu :
>>> somme_des_sous_listes([[1,2,3],[4,5,6]])
[6, 15]
Tests :
# Tests
Affichage :
Console:
Écrire une fonction Python appelée calculer_moyenne_listes
qui prend en paramètre une liste de listes de nombres et renvoie une nouvelle liste contenant la moyenne de chaque sous-liste.
Exemple :
>>> calculer_moyenne_listes([[1,2,3],[4,5,6]])
[2.0, 5.0]
Tests :
# Tests
Affichage :
Console:
Écrire une fonction plus_grand
prenant comme paramètre une liste de listes de nombres et renvoyant le plus grand nombre contenu dans toutes les sous-listes.
Exemple :
>>> plus_grand([[1,2,3],[10,5,8]])
10
Tests :
# Tests
Affichage :
Console:
Nous appellerons "table" une structure de données comportant des données.
Dans ce chapitre, dans Python, une table sera soit :
Comme par exemple :
Nom | Prénom | âge |
---|---|---|
Durand | Jean | 32 |
Vignu | Mauricette | 89 |
Vignu | Capucine | 9 |
Vander | Louise | 17 |
Le format csv est un format de fichier permettant de stocker et lire des tables de données.
C'est un format très utilisé car de nombreux logiciels peuvent lire et écrire dans ce format ce qui permet l'échange de données.
Le langage Python permet d'accéder au contenu d'un fichier csv à l'aide de la bibliothèque csv.
Les commandes sont un peu complexes au début donc les voici :
import os
os.chdir("U:\\") # a modifier
import csv
def export_vers_csv(nom_fichier,liste):
with open(nom_fichier, 'w',encoding='utf-8',newline='') as fichier:
writer = csv.writer(fichier)
writer.writerows(liste)
def import_depuis_csv(nom_fichier):
liste=[]
with open(nom_fichier, 'r',encoding='utf-8',newline='') as fichier:
reader=csv.reader(fichier)
for ligne in reader:
liste.append(ligne)
return liste
nb_eleve(liste)
qui retourne le nombre d'élèves.