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

Dotnet Discussion :

XML vers DataSet : Problème de caractère spéciaux


Sujet :

Dotnet

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    123
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 123
    Points : 77
    Points
    77
    Par défaut XML vers DataSet : Problème de caractère spéciaux
    Bonjour à tous,

    J'ai un problème qui me rend fou!

    Je suis sous Visual Studio 2008/Fwk 3.5 et dans mon appli je charge un DataSet depuis un fichiers XML :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    DataSet ds = new DataSet();
                ds.ReadXml("Y:\\FichierA.xml");
                ds.ReadXml("Y:\\FichierB.xml");
    La différence entre ces deux fichiers est :

    FichierA.xml est un fichier créé avec la même appli qui essaye de le recharger.
    FichierB.xml est un fichier créé sous Visual Studio 2005 en VB.NET dans une Tache Script de SSIS (leurs contenus sont identiques)

    Les deux fichiers contiennent des caractères spéciaux (ç, é ..etc).

    Mon problème est que le fichier FichierA.xml j'arrive à le charger alors que le fichier FichierB.xml me génère une erreur :
    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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
     
    System.Xml.XmlException was unhandled by user code
      Message="Il existe un caractère non valide dans le codage donné. Ligne 104, position 14."
     
      StackTrace:
           à System.Xml.XmlTextReaderImpl.Throw(Exception e)
           à System.Xml.XmlTextReaderImpl.Throw(String res, String arg)
           à System.Xml.XmlTextReaderImpl.Throw(Int32 pos, String res)
           à System.Xml.XmlTextReaderImpl.InvalidCharRecovery(Int32& bytesCount, Int32& charsCount)
           à System.Xml.XmlTextReaderImpl.GetChars(Int32 maxCharsCount)
           à System.Xml.XmlTextReaderImpl.ReadData()
           à System.Xml.XmlTextReaderImpl.ParseText(Int32& startPos, Int32& endPos, Int32& outOrChars)
           à System.Xml.XmlTextReaderImpl.ParseText()
           à System.Xml.XmlTextReaderImpl.ParseElementContent()
           à System.Xml.XmlTextReaderImpl.Read()
           à System.Xml.XmlTextReader.Read()
           à System.Data.DataTextReader.Read()
           à System.Data.XmlDataLoader.LoadData(XmlReader reader)
           à System.Data.DataSet.ReadXml(XmlReader reader, Boolean denyResolving)
           à System.Data.DataSet.ReadXml(String fileName)
     
           à System.Web.UI.WebControls.Button.OnClick(EventArgs e)
           à System.Web.UI.WebControls.Button.RaisePostBackEvent(String eventArgument)
           à System.Web.UI.WebControls.Button.System.Web.UI.IPostBackEventHandler.RaisePostBackEvent(String eventArgument)
           à System.Web.UI.Page.RaisePostBackEvent(IPostBackEventHandler sourceControl, String eventArgument)
           à System.Web.UI.Page.RaisePostBackEvent(NameValueCollection postData)
           à System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint)
      InnerException:
    Quelqu'un a une idée sur la cause de cette erreur?

    Merci d'avance.

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    problème d'encodage a priori...
    Regarde l'encodage qui est indiqué au début du fichier XML, dans la balise <?xml...>. Par exemple :
    Code XML : Sélectionner tout - Visualiser dans une fenêtre à part
    <?xml version="1.0" encoding="utf-8" ?>

    Et vérifie que l'encodage effectif du fichier correspond à ce qui est indiqué (en l'ouvrant avec un éditeur de texte "avancé" comme Notepad2 ou PSPad)

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    123
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 123
    Points : 77
    Points
    77
    Par défaut
    Citation Envoyé par tomlev Voir le message
    problème d'encodage a priori...
    Regarde l'encodage qui est indiqué au début du fichier XML, dans la balise <?xml...>. Par exemple :
    Code XML : Sélectionner tout - Visualiser dans une fenêtre à part
    <?xml version="1.0" encoding="utf-8" ?>

    Et vérifie que l'encodage effectif du fichier correspond à ce qui est indiqué (en l'ouvrant avec un éditeur de texte "avancé" comme Notepad2 ou PSPad)
    FichierA.xml
    Code XML : Sélectionner tout - Visualiser dans une fenêtre à part
    <?xml version="1.0" standalone="yes"?>
    FichierB.xml
    Code XML : Sélectionner tout - Visualiser dans une fenêtre à part
    <?xml version="1.0" standalone="yes"?>

    Exactement la même entête mais pas de balise encoding, est-ce l'encodage par défaut qui peut être différent?

  4. #4
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    Je crois que l'encodage par défaut est UTF-8. Vérifie que les 2 fichiers sont effectivement en UTF-8

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    123
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 123
    Points : 77
    Points
    77
    Par défaut
    Citation Envoyé par tomlev Voir le message
    Je crois que l'encodage par défaut est UTF-8. Vérifie que les 2 fichiers sont effectivement en UTF-8
    J'ai fait barbarement ça :


    FichierA.xml
    Code XML : Sélectionner tout - Visualiser dans une fenêtre à part
    <?xml version="1.0" encoding="utf-8" standalone="yes"?>
    FichierB.xml
    Code XML : Sélectionner tout - Visualiser dans une fenêtre à part
    <?xml version="1.0" encoding="utf-8" standalone="yes"?>

    J'ai toujours le même message d'erreur, par contre je n'arrive pas à trouver comment récupérer le format d'encodage de mes fichiers (alors que ce n'est pas spécifié dans l'entête)?

  6. #6
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    Citation Envoyé par verbal34 Voir le message
    (alors que ce n'est pas spécifié dans l'entête)?
    Tu confonds 2 choses :
    - l'encodage qui est indiqué dans l'en-tête du XML, qui est là pour indiquer au parser comment il doit lire le fichier
    - l'encodage réel du fichier, c'est à dire la façon dont les caractères sont écrits dans le fichier

    Citation Envoyé par verbal34 Voir le message
    par contre je n'arrive pas à trouver comment récupérer le format d'encodage de mes fichiers
    Citation Envoyé par tomlev Voir le message
    (en l'ouvrant avec un éditeur de texte "avancé" comme Notepad2 ou PSPad)
    L'encodage sera indiqué dans la barre de statut.

  7. #7
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    123
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 123
    Points : 77
    Points
    77
    Par défaut
    Désolé de t'avoir fait répéter !
    Effectivement Je confondais entre l'encodage réel et celui du parser ! Plutôt je ne connaissais pas la différence!
    Mon fichier FichierB.xml est encodé en ANSI alors que le FichierA.xml l'est en UTF-8!

    Je les ai réenregistrés en UTF-8 et ça fonctionne!!!

    Merci tomlev pour l'info.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Parsing d'un document XML : Problème des caractères spéciaux
    Par zomurn dans le forum Développement Web en Java
    Réponses: 2
    Dernier message: 18/08/2011, 16h50
  2. [XML] Problème de caractères spéciaux ( & )
    Par kenny49 dans le forum XML/XSL et SOAP
    Réponses: 9
    Dernier message: 17/03/2007, 20h37
  3. [SOAP] problème de caractères spéciaux
    Par ep31 dans le forum XML/XSL et SOAP
    Réponses: 3
    Dernier message: 02/12/2005, 17h43
  4. [Applet][XML] Ne pas interpréter les caractères spéciaux
    Par leminipouce dans le forum Format d'échange (XML, JSON...)
    Réponses: 4
    Dernier message: 28/07/2005, 16h15
  5. [SQL Server] problème de caractères spéciaux
    Par mbibim63 dans le forum MS SQL Server
    Réponses: 10
    Dernier message: 02/06/2005, 18h38

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