Accueil > > > XML VERS TREENODE / TREENODE VERS XML
XML VERS TREENODE / TREENODE VERS XML
Information sur la source
Description
Voici une source basée sur un tutoriel de ce site. Elle repond à bon nombre de sujets postés ici. A savoir : 1- Génération d'un TreeNode à partir d'un document XML. 2- Génération d'un document Xml à partir du même TreeNode. Elle trouve sa principale application dans l'edition d'un document XML à partir du TreeNode généré par cette même source...Utile pour modifier un document... Elle est abondamment commentée.
Source
- #region Generating TreeNode from the Xml document
- /// <summary>
- /// Generates a TreeNode that represents the structure of an XML based document.
- /// </summary>
- /// <param name="cheminFichierAAnalyser">The path of the file you want to get the TreeNode.</param>
- private void getTreeNode()
- {
- //creation du TreeNode
- this._mTreeNode = this.generateTreeNode(this._mRootNode);
- }
-
- private TreeNode generateTreeNode(XmlNode noeud)
- {
- //Creation d'un nouveau TreeNode du nom de la balise XML
- TreeNode tn = new TreeNode(noeud.Name);
-
- //Si il y a des attributs
- if (noeud.Attributes != null && noeud.Attributes.Count > 0)
- {
- //Creation d'un sous-arbre qui recevra les attributs
- TreeNode arbreAttributs = new TreeNode("Attributes");
-
- //Ajout de chaque attribut du noeud au sous-arbre (Nom=Valeur)
- foreach (XmlAttribute attr in noeud.Attributes)
- arbreAttributs.Nodes.Add(attr.Name + "=\"" + attr.Value + "\"");
-
- //Ajout du sous-arbre à l'arbre du noeud
- tn.Nodes.Add(arbreAttributs);
- }
-
- // le sous-element XML n'est pas une balise mais une valeur textuelle
- if (noeud.Value != null && noeud.Value != "")
- //l'arbre portera le nom du noeud
- tn.Text = "Value:"+noeud.Value;
- //Le sous-element est une balise
- else
- {
- // parcours des sous-elements XML
- foreach (XmlNode subxn in noeud.ChildNodes)
-
- // on ajoute le sous-element ainsi que ses propres
- // sous-element recursivement
- tn.Nodes.Add(this.generateTreeNode(subxn));
- }
- //Une fois tous les noeuds traités, retour du TreeNode
- return (tn);
- }
- #endregion
-
-
-
- #region Saving/writing the NewsML document
- private void LaunchWriting(string filename)
- {
- //defintion du writer qui va ecrire le document xml.
- XmlTextWriter w = new XmlTextWriter(filename, System.Text.Encoding.UTF8);
-
- //defintion de l'indentation
- w.Formatting = Formatting.Indented;
- w.Indentation +=2 ;
-
- //ecriture de la declaration xml
- w.WriteStartDocument();
-
- //parcours des treenodes du treeview newsML
- foreach (TreeNode tn in this.treeViewNewsML.Nodes)
- {
- this.writeNewsML(w, tn, filename);
- }
-
- //fermeture du writer
- w.Close();
- }
-
- private void writeNewsML(XmlWriter w, TreeNode tn, string filename)
- {
- //Presence de fils => Soit un noeud pere, soit un noeud d'attributs
- //et differenciation entre les noeuds peres <pere></pere>
- //et les noeuds de valeurs <pere>valeur</pere> materialisés par la chaine "Value:"
- //precedent la dite valeur.
- if (tn.Nodes != null && !tn.Text.StartsWith("Value:"))
- {
- //Ecriture du pere avant ses attributs
- //Si ce n'est pas un arbre d'attributs, c'est un arbre pere.
- if (tn.Text != "Attributes")
- {
- //Ecriture d'une balise ouvrante
- w.WriteStartElement(tn.Text);
- //ecriture de ses attributs. (en les faisant repasser
- //dans la moulinette, ils tomberont dans le "else" suivant)
- foreach (TreeNode n in tn.Nodes)
- {
- this.writeNewsML(w,n,filename);
- }
-
- //Ecriture de la balise fermante
- w.WriteEndElement();
- }
-
- //Si ce n'est pas un pere, c'est un noeud d'attributs,
- //que l'on attribue au pere
- else
- {
- //Ecriture des attributs de l'arbre pere :
- //Pour chaque attribut
- foreach (TreeNode att in tn.Nodes)
- {
- //Recuperation du nom de l'attribut par decoupage de la chaine selon le "=" //(il est avant le "=")
- string attName = att.Text.Split(System.Convert.ToChar("="))[0];
- //Recuperation dde la valuer de l'attribut selon le meme procédé.
- string attValue = att.Text.Split(System.Convert.ToChar("="))[1];
-
- //On vire les caracteres quotes (") presents de chaque coté
- //de la valeur de l'attribut.
- //Le fait de decouper une chaine selon un caractere vire celui-ci.
- attValue = attValue.Split(System.Convert.ToChar("\""))[1];
-
- //ecriture de l'attribut.
- w.WriteAttributeString(attName, attValue );
- }
- }
- }
-
- //Il n'y a pas de fils => les attributs ayant été traités,
- //ils ne doivent pas passer.
- //Ne doivent passer que les valeurs relatives au precedent arbre
- else if (tn.Parent.Text != "Attributes" && tn.Text != "Attributes")
- {
- w.WriteString(tn.Text.Remove(0,6));
- }
- }
- #endregion
#region Generating TreeNode from the Xml document
/// <summary>
/// Generates a TreeNode that represents the structure of an XML based document.
/// </summary>
/// <param name="cheminFichierAAnalyser">The path of the file you want to get the TreeNode.</param>
private void getTreeNode()
{
//creation du TreeNode
this._mTreeNode = this.generateTreeNode(this._mRootNode);
}
private TreeNode generateTreeNode(XmlNode noeud)
{
//Creation d'un nouveau TreeNode du nom de la balise XML
TreeNode tn = new TreeNode(noeud.Name);
//Si il y a des attributs
if (noeud.Attributes != null && noeud.Attributes.Count > 0)
{
//Creation d'un sous-arbre qui recevra les attributs
TreeNode arbreAttributs = new TreeNode("Attributes");
//Ajout de chaque attribut du noeud au sous-arbre (Nom=Valeur)
foreach (XmlAttribute attr in noeud.Attributes)
arbreAttributs.Nodes.Add(attr.Name + "=\"" + attr.Value + "\"");
//Ajout du sous-arbre à l'arbre du noeud
tn.Nodes.Add(arbreAttributs);
}
// le sous-element XML n'est pas une balise mais une valeur textuelle
if (noeud.Value != null && noeud.Value != "")
//l'arbre portera le nom du noeud
tn.Text = "Value:"+noeud.Value;
//Le sous-element est une balise
else
{
// parcours des sous-elements XML
foreach (XmlNode subxn in noeud.ChildNodes)
// on ajoute le sous-element ainsi que ses propres
// sous-element recursivement
tn.Nodes.Add(this.generateTreeNode(subxn));
}
//Une fois tous les noeuds traités, retour du TreeNode
return (tn);
}
#endregion
#region Saving/writing the NewsML document
private void LaunchWriting(string filename)
{
//defintion du writer qui va ecrire le document xml.
XmlTextWriter w = new XmlTextWriter(filename, System.Text.Encoding.UTF8);
//defintion de l'indentation
w.Formatting = Formatting.Indented;
w.Indentation +=2 ;
//ecriture de la declaration xml
w.WriteStartDocument();
//parcours des treenodes du treeview newsML
foreach (TreeNode tn in this.treeViewNewsML.Nodes)
{
this.writeNewsML(w, tn, filename);
}
//fermeture du writer
w.Close();
}
private void writeNewsML(XmlWriter w, TreeNode tn, string filename)
{
//Presence de fils => Soit un noeud pere, soit un noeud d'attributs
//et differenciation entre les noeuds peres <pere></pere>
//et les noeuds de valeurs <pere>valeur</pere> materialisés par la chaine "Value:"
//precedent la dite valeur.
if (tn.Nodes != null && !tn.Text.StartsWith("Value:"))
{
//Ecriture du pere avant ses attributs
//Si ce n'est pas un arbre d'attributs, c'est un arbre pere.
if (tn.Text != "Attributes")
{
//Ecriture d'une balise ouvrante
w.WriteStartElement(tn.Text);
//ecriture de ses attributs. (en les faisant repasser
//dans la moulinette, ils tomberont dans le "else" suivant)
foreach (TreeNode n in tn.Nodes)
{
this.writeNewsML(w,n,filename);
}
//Ecriture de la balise fermante
w.WriteEndElement();
}
//Si ce n'est pas un pere, c'est un noeud d'attributs,
//que l'on attribue au pere
else
{
//Ecriture des attributs de l'arbre pere :
//Pour chaque attribut
foreach (TreeNode att in tn.Nodes)
{
//Recuperation du nom de l'attribut par decoupage de la chaine selon le "=" //(il est avant le "=")
string attName = att.Text.Split(System.Convert.ToChar("="))[0];
//Recuperation dde la valuer de l'attribut selon le meme procédé.
string attValue = att.Text.Split(System.Convert.ToChar("="))[1];
//On vire les caracteres quotes (") presents de chaque coté
//de la valeur de l'attribut.
//Le fait de decouper une chaine selon un caractere vire celui-ci.
attValue = attValue.Split(System.Convert.ToChar("\""))[1];
//ecriture de l'attribut.
w.WriteAttributeString(attName, attValue );
}
}
}
//Il n'y a pas de fils => les attributs ayant été traités,
//ils ne doivent pas passer.
//Ne doivent passer que les valeurs relatives au precedent arbre
else if (tn.Parent.Text != "Attributes" && tn.Text != "Attributes")
{
w.WriteString(tn.Text.Remove(0,6));
}
}
#endregion
Conclusion
Voila pour ce qui est du code...
Sources de la même categorie
Commentaires et avis
|
Derniers Blogs
[WP7] UTILISER UN WRAPPANEL DANS UNE APPLICATION WINDOWS PHONE 7[WP7] UTILISER UN WRAPPANEL DANS UNE APPLICATION WINDOWS PHONE 7 par Audrey
Lors de la réalisation de ma 2ème application Windows Phone 7, j'ai souhaité utiliser un WrapPanel pour afficher plusieurs photos. Mais le contrôle WrapPanel ne fait pas parti de la liste des contrôles inclus dans le SDK de la version Beta des outils pour...
Cliquez pour lire la suite de l'article par Audrey [WP7] BESOIN D'AVOIR DES DONNéES EN CACHE[WP7] BESOIN D'AVOIR DES DONNéES EN CACHE par Nicolas
Les développeurs ASP.NET ont l'habitude de mettre des données en cache pour éviter de requêter a chaque fois la base de données. Et il est toujours utilie de penser que vos utilisateurs mobiles n'ont pas troujours une super connexion 3G/WIFI et un for...
Cliquez pour lire la suite de l'article par Nicolas [TFS] COMMENT FORCER LA SAISIE D'UN AREA OU ITERATION[TFS] COMMENT FORCER LA SAISIE D'UN AREA OU ITERATION par cyril
Lorsque l'on créé un Work Item dans TFS, il est possible de le classer dans un "area" et dans une "iteration". Dans la plupart des types de projet, un "area" correspond à une catégorie, une "iteration" à un numéro de version. Il est possible de cré...
Cliquez pour lire la suite de l'article par cyril SQL : FONCTIONS D'AGRéGATION MIN/MAX ET VALEURS NULLSQL : FONCTIONS D'AGRéGATION MIN/MAX ET VALEURS NULL par coq
Les fonctions d'agrégation comme MIN et MAX ignorent les valeurs NULL présentes dans le jeu de données sur lequel porte leur calcul, d'où le fameux message d'avertissement : Warning: Null value is eliminated by an aggregate or other SET operation...
Cliquez pour lire la suite de l'article par coq VOTEZ POUR WARNYGOVOTEZ POUR WARNYGO par Nicolas
La vidéo du projet Warnygo est disponible sur facebook et attend vos votes ! Pour rappel: Warnygo est une application Windows Phone 7 qui permet d'alerter tous utilisateurs inscrits qui se trouve dans la zone où se passe l'...
Cliquez pour lire la suite de l'article par Nicolas
Logiciels
sDEVIS-FACTURES vlPRO (3.8.0)SDEVIS-FACTURES VLPRO (3.8.0)sDEVIS-FACTURES vlPRO a été mis au point pour permettre besoins des particuliers, créateurs, entr... Cliquez pour télécharger sDEVIS-FACTURES vlPRO LettresFaciles (5.6.0)LETTRESFACILES (5.6.0)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles MyPlanning 2010 (5.6.0)MYPLANNING 2010 (5.6.0)MyPlanning 2010 permet de créer des plannings sous la représentation de diagrammes. Plannings pré... Cliquez pour télécharger MyPlanning 2010 Emicsoft Mac DVD en iPad Convertisseur (3.1.16)EMICSOFT MAC DVD EN IPAD CONVERTISSEUR (3.1.16)Emicsoft Mac DVD en iPad Convertisseur, logiciel professionnel de convertir les fichiers DVD en i... Cliquez pour télécharger Emicsoft Mac DVD en iPad Convertisseur Emicsoft ipad ménager pour mac (3.1.08)EMICSOFT IPAD MéNAGER POUR MAC (3.1.08)Emicsoft ipad ménager pour mac est spécialement conçu pour les utilisateurs Mac pour copier des f... Cliquez pour télécharger Emicsoft ipad ménager pour mac
|