Come analizzare una stringa (LINQ to XML)
In questo articolo viene illustrato come analizzare una stringa per creare un albero XML in C# e in Visual Basic.
Esempio
Nel codice C# seguente viene illustrato come analizzare una stringa XML:
XElement contacts = XElement.Parse(
@"<Contacts>
<Contact>
<Name>Patrick Hines</Name>
<Phone Type=""home"">206-555-0144</Phone>
<Phone Type=""work"">425-555-0145</Phone>
<Address>
<Street1>123 Main St</Street1>
<City>Mercer Island</City>
<State>WA</State>
<Postal>68042</Postal>
</Address>
<NetWorth>10</NetWorth>
</Contact>
<Contact>
<Name>Gretchen Rivas</Name>
<Phone Type=""mobile"">206-555-0163</Phone>
<Address>
<Street1>123 Main St</Street1>
<City>Mercer Island</City>
<State>WA</State>
<Postal>68042</Postal>
</Address>
<NetWorth>11</NetWorth>
</Contact>
</Contacts>");
Console.WriteLine(contacts);
È possibile analizzare una stringa in Visual Basic in modo simile. Tuttavia, è più utile usare valori letterali XML, come illustrato nel codice seguente, perché i valori letterali XML non comportano gli stessi problemi di prestazioni dell'analisi XML da una stringa.
Usando valori letterali XML, è possibile copiare e incollare il codice XML nel programma Visual Basic.
Nota
L'analisi di testo o il caricamento di un documento XML da un file di testo è un processo meno efficiente della costruzione funzionale. Se si inizializza un albero XML dal codice, il tempo CPU richiesto per la costruzione funzionale è inferiore rispetto all'analisi del testo.
Dim contacts as XElement = _
<Contacts>
<Contact>
<Name>Patrick Hines</Name>
<Phone Type="home">206-555-0144</Phone>
<Phone Type="work">425-555-0145</Phone>
<Address>
<Street1>123 Main St</Street1>
<City>Mercer Island</City>
<State>WA</State>
<Postal>68042</Postal>
</Address>
<NetWorth>10</NetWorth>
</Contact>
<Contact>
<Name>Gretchen Rivas</Name>
<Phone Type="mobile">206-555-0163</Phone>
<Address>
<Street1>123 Main St</Street1>
<City>Mercer Island</City>
<State>WA</State>
<Postal>68042</Postal>
</Address>
<NetWorth>11</NetWorth>
</Contact>
</Contacts>
Il nodo Contacts
radice include due nodi Contact
. Per accedere ad alcuni dati specifici nel codice XML analizzato, usare il metodo XElement.Elements(), che in questo caso restituisce gli elementi figlio del nodo Contacts
radice. L'esempio seguente consente di stampare sulla console il primo nodo Contact
:
List<XElement> contactNodes = contacts.Elements("Contact").ToList();
Console.WriteLine(contactNodes[0]);
Dim contactNodes As List(Of XElement) = contacts.Elements("Contact").ToList()
Console.WriteLine(contactNodes(0))