|
Publicité ' | |||||||||||||||||||||||
|
|
#1 |
|
Nouveau Membre du Club
![]() Inscription : avril 2010 Messages : 49 ![]() |
Bonjour,
J'aurais besoin de savoir si c'était possible de récupérer l'encodage d'un fichier (UTF-8, ANSI...) afin d'utiliser dans la foulée la fonction iconv qui basculera mes fichiers en UTF-8 si le fichier ne l'est pas à la base? Merci d'avance. |
|
|
10
|
|
|
#2 |
|
Expert Confirmé
![]() Inscription : janvier 2011 Messages : 970 ![]() |
Salut,
Normalement file -i ton_fichier devrait faire l'affaire
__________________
$ man woman Il n'y a pas de page de manuel pour woman. |
|
|
10
|
|
|
#3 |
|
Nouveau Membre du Club
![]() Inscription : avril 2010 Messages : 49 ![]() |
J'ai le même résultat sur un fichier ANSI et UTF-8 :
fichier_ansi.csv: regular file fichier_utf8.csv: regular file Une autre idée? |
|
|
10
|
|
|
#4 | ||
|
Expert Confirmé
![]() Inscription : janvier 2011 Messages : 970 ![]() |
Re-
Quel système ? Quelle version de file ? Code :
__________________
$ man woman Il n'y a pas de page de manuel pour woman. |
||
|
|
10
|
|
|
#5 |
|
Nouveau Membre du Club
![]() Inscription : avril 2010 Messages : 49 ![]() |
Système : AIX Version 5.3
Version de file : Le file -v ne marche pas... donc je ne sais pas |
|
|
10
|
|
|
#6 |
|
Expert Confirmé
![]() Inscription : janvier 2011 Messages : 970 ![]() |
Il aurait peut être été plus judicieux de poster dans la section Unix et non sur GNU/Linux
Demande à un modo de te rediriger vers le forum adéquat afin d'avoir de meilleures réponses... Désolé
__________________
$ man woman Il n'y a pas de page de manuel pour woman. |
|
|
10
|
|
|
#7 | |
|
Expert Confirmé
![]() Inscription : septembre 2006 Messages : 2 291 ![]() |
Citation:
il n'y a pas de fonction qui détermine de manière univoque l'encoding d'un fichier, mais il est possible de faire un "sniffer" qui va déterminer les encodings possibles/probables du fichier, ce n'est pas compliqué mais c'est d'autant plus de travail que d'encodings à supporter… (google sur "encoding sniffer"…) (NB, pour l'UTF, des BOMs ont été définis mais sont optionnels, si vos fichiers n'en ont pas, vous n'êtes pas plus avancé…) en particulier : si vous ne devez que déterminer le choix entre 2 encodings , il suffit de tester la présence d'un caractère valable dans l'un et pas dans l'autre… à condition que cela existe (par exemple entre ASCII et UTF-8 tout caractère dont le code est ≥ 128 est illégal en ASCII, mais entre ISO-LATIN-1 et UTF-8, il faut voir si l'une des séquences commençant par un car ≥ 128 est non valide en UTF-8 pour supposer que le fichier est en ISO-LATIN-1 parce que non valide en UTF-8 mais il est possible d'avoir un fichier valide dans les 2 encodings en termes de séquence de bytes…) . maintenant en pratique : qu'entendez-vous exactement par ANSI ? En termes d'encoding de fichier, le terme ANSI désigne une classe d'encoding pas un encoding particulier… il faut encore le code page (1252 pour Windows, 54936 pour le Chinois simplifié, etc.) |
|
|
|
10
|
|
|
#8 |
|
Nouveau Membre du Club
![]() Inscription : avril 2010 Messages : 49 ![]() |
En fait je doit partir de l'idée que je ne connais pas l'encodage du fichier sur lequel je dois appliquer un iconv. Hors iconv à besoin qu'on lui propose le format d'origine pour qu'il arrive à faire la conversion vers l'encodage UTF-8 que je veux. A moins que je me trompe, il est peut être possible d'utiliser iconv sans connaître l'encodage d'origine...
|
|
|
10
|
|
|
#9 | |
|
Expert Confirmé
![]() Inscription : septembre 2006 Messages : 2 291 ![]() |
Citation:
MAIS çà ne voudra pas dire que c'est le seul encoding compatible… et donc que ce soit le "bon"… pour un lecteur humain. |
|
|
|
00
|
|
|
#10 |
|
Nouveau Membre du Club
![]() Inscription : avril 2010 Messages : 49 ![]() |
Le problème c'est que je n'arrive pas à trouver un moyen d'obtenir l'encoding à placer dans le FORM, je vais essayer de voir si je peux modifier quelque chose sur le serveur afin de pouvoir utiliser file -i
|
|
|
00
|
|
|
#11 |
|
Membre Expert
![]() Ingénieur développement logiciels Inscription : octobre 2008 Messages : 1 375 ![]() |
Comme on te l'a déjà dit il n'est pas possible de deviner avec certitude l'encodage d'un fichier. Le mieux c'est que tu essaies de faire un iconv avec différent choix "raisonables" pour l'encodage de départ. Si iconv fait une erreur ce n'est pas bon. Si iconv ne fait pas d'erreur ça ne veut pas dire que c'est bon ; il faut encore que tu ailles voir le fichier converti pour voir si le résultat te convient.
En général il n'y a pas 36 possibilités différentes pour l'encodage d'un fichier. Par exemple si c'est un fichier en français ou en anglais, tu peux essayer ISO-8859-1, ISO-8859-15, CP1252 (utilisé sous Windows), UTF8, UTF16. |
|
|
00
|
Copyright © 2000-2012 - www.developpez.com