Comma-separated values
Extension |
.csv |
---|---|
Type MIME |
text/csv |
Type de format | |
Norme |
(en) RFC 4180 |
Spécification |
Comma-separated values, connu sous le sigle CSV, est un format informatique ouvert représentant des données tabulaires sous forme de valeurs séparées par des virgules.
Ce format n'a jamais vraiment fait l'objet d'une spécification formelle. Toutefois, la RFC 4180 décrit la forme la plus courante et établit son type MIME « text/csv
», enregistré auprès de l'IANA.
Un fichier CSV est un fichier texte, par opposition aux formats dits « binaires ». Chaque ligne du texte correspond à une ligne du tableau et les virgules correspondent aux séparations entre les colonnes. Les portions de texte séparées par une virgule correspondent ainsi aux contenus des cellules du tableau.
Une ligne est une suite ordonnée de caractères terminée par un caractère de fin de ligne (line break – CRLF), la dernière ligne pouvant en être exemptée.
Par exemple :
Sexe,Prénom,Année de naissance M,Alphonse,1932 F,Béatrice,1964 F,Charlotte,1988
représente les données suivantes :
Sexe | Prénom | Année de naissance |
---|---|---|
M | Alphonse | 1932 |
F | Béatrice | 1964 |
F | Charlotte | 1988 |
Variantes françaises
Le fait que les fichiers CSV soient essentiellement utilisés autour de logiciels tableur comme Microsoft Excel, et que les séparateurs ne soient pas standardisés (virgules, points-virgules sous certaines localisations dont la française, etc.) rend ce format peu pratique pour une utilisation autre que des échanges de données ponctuels. Ce format est toutefois assez populaire parce qu'il semble relativement facile à générer.
Les champs texte peuvent également être délimités par des guillemets. Lorsqu'un champ contient lui-même des guillemets, ils sont doublés afin de ne pas être considérés comme début ou fin du champ. Si un champ contient un signe utilisé comme séparateur (virgule, point-virgule, etc.), les guillemets sont obligatoires afin que ce signe ne soit pas confondu avec un séparateur.
Exemple, avec des champs séparés par des points-virgules et des guillemets :
Robert;Dupont;rue du Verger, 12;… "Michel";"Durand";" av. de la Ferme, 89 ";… "Michel ""Michele""";"Durand";" av. de la Ferme, 89";… "Michel;Michele";"Durand";"av. de la Ferme, 89";…
Ce texte représente les données suivantes :
Robert | Dupont | rue du Verger, 12 | … |
Michel | Durand | av. de la Ferme, 89 | … |
Michel "Michele" | Durand | av. de la Ferme, 89 | … |
Michel;Michele | Durand | av. de la Ferme, 89 | … |
Alternatives
Le format CSV présente entre autres inconvénients d'être interprété par Microsoft Excel comme étant au format anglais (séparateur de colonnes : virgule ; séparateur de décimales : point) ou français de France (séparateur de colonnes : point-virgule ; séparateur de décimales : virgule) en fonction de l'origine du fichier : sur disque, par HTTP, support amovible…
Le format SYLK présente l'avantage d'être un format texte et d'être indépendant de la langue de Microsoft Excel (anglais, français…). Il peut intégrer des formules mathématiques simples et contrôler certaines propriétés des cellules. De plus, les cellules du tableur peuvent être remplies dans le désordre.
Une alternative est le XML pour l'import sur un logiciel tableur comme Microsoft Excel.