XPathExpression.Compile Metoda
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
Zkompiluje zadaný výraz XPath a vrátí XPathExpression objekt, který představuje výraz XPath.
Přetížení
Compile(String) |
Zkompiluje zadaný výraz XPath a vrátí XPathExpression objekt představující výraz XPath. |
Compile(String, IXmlNamespaceResolver) |
Zkompiluje zadaný výraz XPath s objektem IXmlNamespaceResolver určeným pro rozlišení oboru názvů a vrátí XPathExpression objekt, který představuje výraz XPath. |
Compile(String)
Zkompiluje zadaný výraz XPath a vrátí XPathExpression objekt představující výraz XPath.
public:
static System::Xml::XPath::XPathExpression ^ Compile(System::String ^ xpath);
public static System.Xml.XPath.XPathExpression Compile (string xpath);
static member Compile : string -> System.Xml.XPath.XPathExpression
Public Shared Function Compile (xpath As String) As XPathExpression
Parametry
- xpath
- String
Výraz XPath.
Návraty
Objekt XPathExpression.
Výjimky
Parametr výrazu XPath není platný výraz XPath.
Výraz XPath není platný.
Příklady
Následující příklad ukazuje, jak pomocí návratového typu XPath určit, jak zpracovat výraz XPath. Příklad používá metodu Compile k vrácení nových XPathExpression objektů.
public ref class Sample
{
public:
static void Evaluate( XPathExpression^ expr, XPathNavigator^ nav )
{
XPathNodeIterator^ i = nav->Select(expr);
switch ( expr->ReturnType )
{
case XPathResultType::Number:
Console::WriteLine( nav->Evaluate( expr ) );
break;
case XPathResultType::NodeSet:
while ( i->MoveNext() )
Console::WriteLine( i->Current );
break;
case XPathResultType::Boolean:
if ( *safe_cast<bool^>(nav->Evaluate( expr )) )
Console::WriteLine( "True!" );
break;
case XPathResultType::String:
Console::WriteLine( nav->Evaluate( expr ) );
break;
}
}
};
int main()
{
XPathDocument^ doc = gcnew XPathDocument( "contosoBooks.xml" );
XPathNavigator^ nav = doc->CreateNavigator();
XPathExpression^ expr1 = nav->Compile( ".//price/text()*10" ); // Returns a number.
XPathExpression^ expr2 = nav->Compile( "bookstore/book/price" ); // Returns a nodeset.
Sample^ MySample = gcnew Sample;
MySample->Evaluate( expr1, nav );
MySample->Evaluate( expr2, nav );
}
using System;
using System.Xml;
using System.Xml.XPath;
public class XPathExpressionExample
{
public static void Main()
{
XPathDocument document = new XPathDocument("contosoBooks.xml");
XPathNavigator navigator = document.CreateNavigator();
XPathExpression expression1 = XPathExpression.Compile(".//bk:price/text()*10"); // Returns a number.
XPathExpression expression2 = XPathExpression.Compile("bk:bookstore/bk:book/bk:price"); // Returns a nodeset.
XmlNamespaceManager manager = new XmlNamespaceManager(navigator.NameTable);
manager.AddNamespace("bk", "http://www.contoso.com/books");
expression1.SetContext(manager);
expression2.SetContext(manager);
Evaluate(expression1, navigator);
Evaluate(expression2, navigator);
}
public static void Evaluate(XPathExpression expression, XPathNavigator navigator)
{
switch (expression.ReturnType)
{
case XPathResultType.Number:
Console.WriteLine(navigator.Evaluate(expression));
break;
case XPathResultType.NodeSet:
XPathNodeIterator nodes = navigator.Select(expression);
while (nodes.MoveNext())
{
Console.WriteLine(nodes.Current.ToString());
}
break;
case XPathResultType.Boolean:
if ((bool)navigator.Evaluate(expression))
Console.WriteLine("True!");
break;
case XPathResultType.String:
Console.WriteLine(navigator.Evaluate(expression));
break;
}
}
}
Imports System.Xml
Imports System.Xml.XPath
Public Class XPathExpressionExample
Public Shared Sub Main()
Dim document As XPathDocument = New XPathDocument("contosoBooks.xml")
Dim navigator As XPathNavigator = document.CreateNavigator()
Dim expression1 As XPathExpression = XPathExpression.Compile(".//bk:price/text()*10") ' Returns a number.
Dim expression2 As XPathExpression = XPathExpression.Compile("bk:bookstore/bk:book/bk:price") ' Returns a nodeset.
Dim manager As XmlNamespaceManager = New XmlNamespaceManager(navigator.NameTable)
manager.AddNamespace("bk", "http://www.contoso.com/books")
expression1.SetContext(manager)
expression2.SetContext(manager)
Evaluate(expression1, navigator)
Evaluate(expression2, navigator)
End Sub
Public Shared Sub Evaluate(ByVal expression As XPathExpression, ByVal navigator As XPathNavigator)
Select Case expression.ReturnType
Case XPathResultType.Number
Console.WriteLine(navigator.Evaluate(expression))
Exit Sub
Case XPathResultType.NodeSet
Dim nodes As XPathNodeIterator = navigator.Select(expression)
While nodes.MoveNext()
Console.WriteLine(nodes.Current.ToString())
End While
Case XPathResultType.Boolean
If CType(navigator.Evaluate(expression), Boolean) Then
Console.WriteLine("True!")
End If
Case XPathResultType.String
Console.WriteLine(navigator.Evaluate(expression))
End Select
End Sub
End Class
Příklad vezme contosoBooks.xml
soubor jako vstup.
<?xml version="1.0" encoding="utf-8" ?>
<bookstore xmlns="http://www.contoso.com/books">
<book genre="autobiography" publicationdate="1981-03-22" ISBN="1-861003-11-0">
<title>The Autobiography of Benjamin Franklin</title>
<author>
<first-name>Benjamin</first-name>
<last-name>Franklin</last-name>
</author>
<price>8.99</price>
</book>
<book genre="novel" publicationdate="1967-11-17" ISBN="0-201-63361-2">
<title>The Confidence Man</title>
<author>
<first-name>Herman</first-name>
<last-name>Melville</last-name>
</author>
<price>11.99</price>
</book>
<book genre="philosophy" publicationdate="1991-02-15" ISBN="1-861001-57-6">
<title>The Gorgias</title>
<author>
<name>Plato</name>
</author>
<price>9.99</price>
</book>
</bookstore>
Poznámky
Výraz XPath se vyhodnotí tak, aby získal jeden z následujících typů výsledků.
Poznámka
Pokud je ve výrazu XPath zadána funkce definovaná uživatelem s neplatným počtem argumentů (nebo neplementovanou uživatelem definovanou funkcí), dojde k výjimce pouze v době běhu. Uživatelem definované funkce nejsou kontrolovány v době kompilace a výjimky, které mají za následek uživatelem definované funkce, dojde pouze v případě, že provádění vyhodnotí výraz.
Viz také
Platí pro
Compile(String, IXmlNamespaceResolver)
Zkompiluje zadaný výraz XPath s objektem IXmlNamespaceResolver určeným pro rozlišení oboru názvů a vrátí XPathExpression objekt, který představuje výraz XPath.
public:
static System::Xml::XPath::XPathExpression ^ Compile(System::String ^ xpath, System::Xml::IXmlNamespaceResolver ^ nsResolver);
public static System.Xml.XPath.XPathExpression Compile (string xpath, System.Xml.IXmlNamespaceResolver? nsResolver);
public static System.Xml.XPath.XPathExpression Compile (string xpath, System.Xml.IXmlNamespaceResolver nsResolver);
static member Compile : string * System.Xml.IXmlNamespaceResolver -> System.Xml.XPath.XPathExpression
Public Shared Function Compile (xpath As String, nsResolver As IXmlNamespaceResolver) As XPathExpression
Parametry
- xpath
- String
Výraz XPath.
- nsResolver
- IXmlNamespaceResolver
Objekt, který implementuje IXmlNamespaceResolver rozhraní pro překlad oboru názvů.
Návraty
Objekt XPathExpression.
Výjimky
Parametr výrazu XPath není platný výraz XPath.
Výraz XPath není platný.
Poznámky
Výraz XPath se vyhodnotí tak, aby získal jeden z následujících typů výsledků.
Poznámka
Pokud je ve výrazu XPath zadána uživatelsky definovaná funkce s neplatným počtem argumentů (nebo neplementovanou uživatelem definovanou funkcí), dojde k výjimce pouze za běhu. Uživatelem definované funkce nejsou kontrolovány v době kompilace a výjimky vyplývající z uživatelem definovaných funkcí se vyskytují pouze v případě, že provádění vyhodnotí výraz.
Poznámka
Není možné zkompilovat XPathExpression vlastní kontext v jednom kroku předáním XsltContext, který implementuje IXmlNamespaceResolver, jako argument pro tuto metodu. Pokud chcete použít XPathExpression vlastní kontext, musíte po kompilaci výrazu SetContext volat metodu.