Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

XPATH : UTILISEZ DES REQUÊTES PARAMÉTRÉES


Information sur la source

Catégorie :.NET Source .NET ( DotNet ) Classé sous : xpath, paramètre, xsltcontext, ixsltcontextvariable Niveau : Débutant Date de création : 18/03/2007 Vu / téléchargé: 6 118 / 229

Note :
9,67 / 10 - par 3 personnes
9,67 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

Commentaire sur cette source (3)
Ajouter un commentaire et/ou une note


Description

Il s'agit des sources utilisées pour le post "XPath : utilisez des requêtes paramétrées" que vous trouverez ici : http://blogs.codes-sources.com/coq/archive/2007/03/18/xpath-utilisez-des-requ-tes-param-tr-es.aspx

Ces sources contiennent notamment le contexte personnalisé : la classe CustomContext.
 

Source

  • using System;
  • using System.Xml;
  • using System.Xml.Xsl;
  • using System.Xml.XPath;
  • using System.Collections.Generic;
  • namespace PersonsXPath
  • {
  • class CustomContext : XsltContext
  • {
  • #region Constructeurs
  • public CustomContext()
  • : base()
  • {
  • }
  • public CustomContext(NameTable table)
  • : base(table)
  • {
  • }
  • #endregion Constructeurs
  • #region Champs
  • /// <summary>
  • /// Contient les variables.
  • /// </summary>
  • private Dictionary<String, IXsltContextVariable> _variables
  • = new Dictionary<String, IXsltContextVariable>();
  • #endregion Champs
  • #region Implémentation de XsltContext
  • public override int CompareDocument(String baseUri, String nextbaseUri)
  • {
  • // Nous utilisons simplement une comparaison de chaîne.
  • return String.CompareOrdinal(baseUri, nextbaseUri);
  • }
  • public override bool PreserveWhitespace(System.Xml.XPath.XPathNavigator node)
  • {
  • return true;
  • }
  • public override bool Whitespace
  • {
  • get
  • {
  • return true;
  • }
  • }
  • public override IXsltContextFunction ResolveFunction(
  • String prefix,
  • String name,
  • XPathResultType[] ArgTypes)
  • {
  • // Inutile dans notre cas, nous ne nous intéressons qu'aux variables.
  • return null;
  • }
  • public override IXsltContextVariable ResolveVariable(String prefix, String name)
  • {
  • IXsltContextVariable var = null;
  • this._variables.TryGetValue(name, out var);
  • return var;
  • }
  • #endregion Implémentation de XsltContext
  • #region Gestion des paramètres
  • public void AddVariable(String name, Object value)
  • {
  • #region Vérification des paramètres
  • if (name == null)
  • throw new ArgumentNullException("name");
  • else if (name.Length < 0)
  • throw new ArgumentException("name");
  • if (value == null)
  • throw new ArgumentNullException("value");
  • #endregion Vérification des paramètres
  • this._variables[name] = new Variable(name, value);
  • }
  • public Boolean RemoveVariable(String name)
  • {
  • #region Vérification des paramètres
  • if (name == null)
  • throw new ArgumentNullException("name");
  • else if (name.Length < 0)
  • throw new ArgumentException("name");
  • #endregion Vérification des paramètres
  • return this._variables.Remove(name);
  • }
  • public void ClearVariables()
  • {
  • this._variables.Clear();
  • }
  • #endregion Gestion des paramètres
  • private class Variable : IXsltContextVariable
  • {
  • #region Constructeur
  • /// <summary>
  • /// Initialise une nouvelle instance de <see cref="Variable"/>.
  • /// </summary>
  • /// <param name="name"></param>
  • /// <param name="value"></param>
  • /// <exception cref="ArgumentNullException">
  • /// <c>name</c> est une référence nulle.
  • /// ou
  • /// <c>value</c> est une référence nulle.
  • /// </exception>
  • /// <exception cref="ArgumentException">
  • /// <c>name</c> est une chaîne vide.
  • /// </exception>
  • public Variable(String name, Object value)
  • {
  • #region Vérification des paramètres
  • if (name == null)
  • throw new ArgumentNullException("name");
  • else if (name.Length < 0)
  • throw new ArgumentException("name");
  • if (value == null)
  • throw new ArgumentNullException("value");
  • #endregion Vérification des paramètres
  • this._name = name;
  • this._value = value;
  • this.DetermineType();
  • }
  • #endregion Constructeur
  • #region Champs
  • /// <summary>
  • /// Nom de la variable.
  • /// </summary>
  • private String _name;
  • /// <summary>
  • /// Valeur de la variable.
  • /// </summary>
  • private Object _value;
  • /// <summary>
  • /// Type de la variable.
  • /// </summary>
  • private XPathResultType _type;
  • #endregion Champs
  • #region Propriétés
  • /// <summary>
  • /// Obtient ou définit le nom de la variable.
  • /// </summary>
  • public String Name
  • {
  • get
  • {
  • return this._name;
  • }
  • set
  • {
  • this._name = value;
  • }
  • }
  • /// <summary>
  • /// Obtient ou définit la valeur de la variable.
  • /// </summary>
  • public Object Value
  • {
  • get
  • {
  • return this._value;
  • }
  • set
  • {
  • this._value = value;
  • }
  • }
  • #endregion Propriétés
  • #region Implémentation de IXsltContextVariable
  • public object Evaluate(XsltContext xsltContext)
  • {
  • return this._value;
  • }
  • public Boolean IsLocal
  • {
  • get
  • {
  • return false;
  • }
  • }
  • public Boolean IsParam
  • {
  • get
  • {
  • return false;
  • }
  • }
  • public XPathResultType VariableType
  • {
  • get
  • {
  • return this._type;
  • }
  • }
  • #endregion Implémentation de IXsltContextVariable
  • #region Méthodes utilitaires
  • /// <summary>
  • /// Permet de déterminer le type de la valeur.
  • /// </summary>
  • private void DetermineType()
  • {
  • // Détermination des types :
  • // String : XPathResultType.String
  • // Boolean : XPathResultType.Boolean
  • // XPathNavigator : XPathResultType.Navigator
  • // XPathNodeIterator : XPathResultType.NodeSet
  • // Double : XPathResultType.Number
  • // Convertible en Double : XPathResultType.Number
  • // Autres : XPathResultType.Any
  • if (this._value is String)
  • this._type = XPathResultType.String;
  • else if (this._value is Boolean)
  • this._type = XPathResultType.Boolean;
  • else if (this._value is XPathNavigator)
  • this._type = XPathResultType.Navigator;
  • else if (this._value is XPathNodeIterator)
  • this._type = XPathResultType.NodeSet;
  • else if (this._value is Double)
  • this._type = XPathResultType.Number;
  • else if (this._value is IConvertible)
  • {
  • // Si le type n'est pas double mais implémente IConvertible,
  • // nous tentons la conversion.
  • try
  • {
  • this._value = Convert.ToDouble(this._value);
  • this._type = XPathResultType.Number;
  • }
  • catch
  • {
  • this._type = XPathResultType.Any;
  • }
  • }
  • else
  • this._type = XPathResultType.Any;
  • }
  • #endregion Méthodes utilitaires
  • }
  • }
  • }
using System;
using System.Xml;
using System.Xml.Xsl;
using System.Xml.XPath;
using System.Collections.Generic;

namespace PersonsXPath
{
    class CustomContext : XsltContext
    {
        #region Constructeurs

        public CustomContext()
            : base()
        {
        }

        public CustomContext(NameTable table)
            : base(table)
        {
        }

        #endregion Constructeurs

        #region Champs

        /// <summary>
        /// Contient les variables.
        /// </summary>
        private Dictionary<String, IXsltContextVariable> _variables
            = new Dictionary<String, IXsltContextVariable>();

        #endregion Champs

        #region Implémentation de XsltContext

        public override int CompareDocument(String baseUri, String nextbaseUri)
        {
            // Nous utilisons simplement une comparaison de chaîne.
            return String.CompareOrdinal(baseUri, nextbaseUri);
        }

        public override bool PreserveWhitespace(System.Xml.XPath.XPathNavigator node)
        {
            return true;
        }

        public override bool Whitespace
        {
            get
            {
                return true;
            }
        }

        public override IXsltContextFunction ResolveFunction(
            String prefix,
            String name,
            XPathResultType[] ArgTypes)
        {
            // Inutile dans notre cas, nous ne nous intéressons qu'aux variables.
            return null;
        }

        public override IXsltContextVariable ResolveVariable(String prefix, String name)
        {
            IXsltContextVariable var = null;
            this._variables.TryGetValue(name, out var);
            return var;
        }

        #endregion Implémentation de XsltContext

        #region Gestion des paramètres

        public void AddVariable(String name, Object value)
        {
            #region Vérification des paramètres

            if (name == null)
                throw new ArgumentNullException("name");
            else if (name.Length < 0)
                throw new ArgumentException("name");

            if (value == null)
                throw new ArgumentNullException("value");

            #endregion Vérification des paramètres

            this._variables[name] = new Variable(name, value);
        }

        public Boolean RemoveVariable(String name)
        {
            #region Vérification des paramètres

            if (name == null)
                throw new ArgumentNullException("name");
            else if (name.Length < 0)
                throw new ArgumentException("name");

            #endregion Vérification des paramètres

            return this._variables.Remove(name);
        }

        public void ClearVariables()
        {
            this._variables.Clear();
        }

        #endregion Gestion des paramètres

        private class Variable : IXsltContextVariable
        {
            #region Constructeur

            /// <summary>
            /// Initialise une nouvelle instance de <see cref="Variable"/>.
            /// </summary>
            /// <param name="name"></param>
            /// <param name="value"></param>
            /// <exception cref="ArgumentNullException">
            /// <c>name</c> est une référence nulle. 
            /// ou 
            /// <c>value</c> est une référence nulle. 
            /// </exception>
            /// <exception cref="ArgumentException">
            /// <c>name</c> est une chaîne vide.
            /// </exception>
            public Variable(String name, Object value)
            {
                #region Vérification des paramètres

                if (name == null)
                    throw new ArgumentNullException("name");
                else if (name.Length < 0)
                    throw new ArgumentException("name");

                if (value == null)
                    throw new ArgumentNullException("value");

                #endregion Vérification des paramètres

                this._name = name;
                this._value = value;

                this.DetermineType();
            }

            #endregion Constructeur

            #region Champs

            /// <summary>
            /// Nom de la variable.
            /// </summary>
            private String _name;

            /// <summary>
            /// Valeur de la variable.
            /// </summary>
            private Object _value;

            /// <summary>
            /// Type de la variable.
            /// </summary>
            private XPathResultType _type;

            #endregion Champs

            #region Propriétés

            /// <summary>
            /// Obtient ou définit le nom de la variable.
            /// </summary>
            public String Name
            {
                get
                {
                    return this._name;
                }

                set
                {
                    this._name = value;
                }
            }

            /// <summary>
            /// Obtient ou définit la valeur de la variable.
            /// </summary>
            public Object Value
            {
                get
                {
                    return this._value;
                }

                set
                {
                    this._value = value;
                }
            }

            #endregion Propriétés

            #region Implémentation de IXsltContextVariable

            public object Evaluate(XsltContext xsltContext)
            {
                return this._value;
            }

            public Boolean IsLocal
            {
                get
                {
                    return false;
                }
            }

            public Boolean IsParam
            {
                get
                {
                    return false;
                }
            }

            public XPathResultType VariableType
            {
                get
                {
                    return this._type;
                }
            }

            #endregion Implémentation de IXsltContextVariable

            #region Méthodes utilitaires

            /// <summary>
            /// Permet de déterminer le type de la valeur.
            /// </summary>
            private void DetermineType()
            {
                // Détermination des types : 
                // String                : XPathResultType.String
                // Boolean               : XPathResultType.Boolean
                // XPathNavigator        : XPathResultType.Navigator
                // XPathNodeIterator     : XPathResultType.NodeSet
                // Double                : XPathResultType.Number
                // Convertible en Double : XPathResultType.Number
                // Autres                : XPathResultType.Any

                if (this._value is String)
                    this._type = XPathResultType.String;
                else if (this._value is Boolean)
                    this._type = XPathResultType.Boolean;
                else if (this._value is XPathNavigator)
                    this._type = XPathResultType.Navigator;
                else if (this._value is XPathNodeIterator)
                    this._type = XPathResultType.NodeSet;
                else if (this._value is Double)
                    this._type = XPathResultType.Number;
                else if (this._value is IConvertible)
                {
                    // Si le type n'est pas double mais implémente IConvertible, 
                    // nous tentons la conversion.
                    try
                    {
                        this._value = Convert.ToDouble(this._value);
                        this._type = XPathResultType.Number;
                    }
                    catch
                    {
                        this._type = XPathResultType.Any;
                    }
                }
                else
                    this._type = XPathResultType.Any;
            }

            #endregion Méthodes utilitaires
        }
    }
}

Fichier Zip

Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip

Commentaires et avis

signaler à un administrateur
Commentaire de romagny13 le 18/03/2007 12:43:03

Ouuuf alors la je dis "trop" merci
moi qui ai pas une seconde a moi
ca va peut etre m'avancer pas mal a ce niveau car j'ai toujours pas regarder sur msdn comment les utiliser
merci

signaler à un administrateur
Commentaire de Bidou le 20/03/2007 15:49:42 administrateur CS

J'espère que ce coup de pub n'est pas trop mal placé ;-p
http://www.csharpfr.com/tutorial.aspx?ID=536

signaler à un administrateur
Commentaire de coq le 21/03/2007 18:48:09 administrateur CS

Lol, fait toi plaisir.

Ajouter un commentaire

Discussions en rapport avec ce code source dans le forum

Requetes Xpath [ par rintchu ] Bonjour, voici mon probleme :je veux faire une requete Xpath a partir d'un XMlNode n, je fais :n.SelectSingleNode(Myreqeuete)Le probleme , c'est que s Paramètre entre 2 forms [ par stailer ] Salut tout le monde,Je continue mon apprentissage à C# avec sharpdevelop et me voila confronté à un nouveau problème.Mon projet contient 2 forms. J'ai Passages de paramètres Datagrid => Formulaire [ par Kati83 ] Bonjour à tous,J'ai une datagrid qui affiche certaines des informations de ma bd.Elle contient aussi deux colonnes de boutons : supprimer et modifier. [c#],paramètre [ par stiley1 ] Bjour je désire entrer le chemin d'un fichier ds ma bd pour pouvoir le recupérer +tard. et je fais ceci:Code: string cont = System.IO.Path.GetFullPath Problème avec SystemParametersInfo [ par Caryl ] Je veux utiliser le paramètre SPI_SETDESKWALLPAPER comme uiAction pour SystemParametersInfo mais dans l'aide de VS.Net uiAction doit être un Uint. Je Crystal Report ? Paramètre [ par frusciante80 ] Bonjour,Alors voila j'ai comme vous vous en doutez un petit problème.Je dois faire une impression de license via un programme qu'on developpe actuelle thread paramètre [ par abdoulax ] En fait voila mon pb :Je voudrai créer un thread qui appel une fonction en lui passant des paramètre.Si qlq1 connait aussi un bon site sur le dotnet o Envoyer des paramètres à un thread [ par billou_13 ] J'aurai voulu savoir s'il y avait moyen d'envoyer un param&#232;tre dans un nouveau thread !Parce que d&#232;s que je cr&#233;&#233; un thread : je po [C#] Lançer une form depuis une autre avec un paramètre [ par nitrique ] Bonjour, Je d&#233;bute... J'ai deux forms, ma principale (pri) et une autre (sec) dans une application winforms. Tout dabord, j'aimerais savoir comm Datagrid + DataSet [ par emmanuel9 ] Bonjour, En faite ce qui ce passe, c'est que j'ai un tableau de param&#232;tre avec plusieurs colonnes sur le papier. Et je dois le retranscrire sur p


Nos sponsors

Sondage...

CalendriCode

Juillet 2009
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
2728293031  

Consulter la suite du CalendriCode

Téléchargements

Logiciels à télécharger sur le même thème :

Comparez les prix Nouvelle version

Photothèque Nouveau !



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,312 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.