Assembly: System.Xml (in system.xml.dll)
Public Overrides Function Read As Boolean
Dim instance As XmlTextReader Dim returnValue As Boolean returnValue = instance.Read
public override bool Read ()
public: virtual bool Read () override
public boolean Read ()
public override function Read () : boolean
Valore restituito
true se è stata completata la lettura del nodo successivo; false se non esistono altri nodi da leggere.| Tipo di eccezione | Condizione |
|---|---|
| Si è verificato un errore durante l'analisi dell'XML. |
Nota |
|---|
| Nella versione Microsoft .NET Framework versione 2.0 è consigliabile creare istanze di XmlReader utilizzando il metodo System.Xml.XmlReader.Create. In questo modo è possibile sfruttare completamente le nuove funzionalità introdotte in questa versione. Per ulteriori informazioni, vedere Creazione di lettori XML. |
Quando si crea e si inizializza per la prima volta un visualizzatore, non è disponibile alcuna informazione. È necessario chiamare il metodo Read per leggere il primo nodo.
Nell'esempio seguente viene letto un file XML e vengono visualizzati tutti i nodi.
Option Strict Option Explicit Imports System Imports System.IO Imports System.Xml 'Reads an XML document Public Class Sample Private Const filename As String = "items.xml" Public Shared Sub Main() Dim reader As XmlTextReader = Nothing Try ' Load the reader with the data file and ignore all white space nodes. reader = New XmlTextReader(filename) reader.WhitespaceHandling = WhitespaceHandling.None ' Parse the file and display each of the nodes. While reader.Read() Select Case reader.NodeType Case XmlNodeType.Element Console.Write("<{0}>", reader.Name) Case XmlNodeType.Text Console.Write(reader.Value) Case XmlNodeType.CDATA Console.Write("<![CDATA[{0}]]>", reader.Value) Case XmlNodeType.ProcessingInstruction Console.Write("<?{0} {1}?>", reader.Name, reader.Value) Case XmlNodeType.Comment Console.Write("<!--{0}-->", reader.Value) Case XmlNodeType.XmlDeclaration Console.Write("<?xml version='1.0'?>") Case XmlNodeType.Document Case XmlNodeType.DocumentType Console.Write("<!DOCTYPE {0} [{1}]", reader.Name, reader.Value) Case XmlNodeType.EntityReference Console.Write(reader.Name) Case XmlNodeType.EndElement Console.Write("</{0}>", reader.Name) End Select End While Finally If Not (reader Is Nothing) Then reader.Close() End If End Try End Sub 'Main End Class 'Sample
using System; using System.IO; using System.Xml; public class Sample { private const String filename = "items.xml"; public static void Main() { XmlTextReader reader = null; try { // Load the reader with the data file and ignore all white space nodes. reader = new XmlTextReader(filename); reader.WhitespaceHandling = WhitespaceHandling.None; // Parse the file and display each of the nodes. while (reader.Read()) { switch (reader.NodeType) { case XmlNodeType.Element: Console.Write("<{0}>", reader.Name); break; case XmlNodeType.Text: Console.Write(reader.Value); break; case XmlNodeType.CDATA: Console.Write("<![CDATA[{0}]]>", reader.Value); break; case XmlNodeType.ProcessingInstruction: Console.Write("<?{0} {1}?>", reader.Name, reader.Value); break; case XmlNodeType.Comment: Console.Write("<!--{0}-->", reader.Value); break; case XmlNodeType.XmlDeclaration: Console.Write("<?xml version='1.0'?>"); break; case XmlNodeType.Document: break; case XmlNodeType.DocumentType: Console.Write("<!DOCTYPE {0} [{1}]", reader.Name, reader.Value); break; case XmlNodeType.EntityReference: Console.Write(reader.Name); break; case XmlNodeType.EndElement: Console.Write("</{0}>", reader.Name); break; } } } finally { if (reader!=null) reader.Close(); } } } // End class
#using <System.Xml.dll> using namespace System; using namespace System::IO; using namespace System::Xml; int main() { XmlTextReader^ reader = nullptr; String^ filename = "items.xml"; try { // Load the reader with the data file and ignore all white space nodes. reader = gcnew XmlTextReader( filename ); reader->WhitespaceHandling = WhitespaceHandling::None; // Parse the file and display each of the nodes. while ( reader->Read() ) { switch ( reader->NodeType ) { case XmlNodeType::Element: Console::Write( "<{0}>", reader->Name ); break; case XmlNodeType::Text: Console::Write( reader->Value ); break; case XmlNodeType::CDATA: Console::Write( "<![CDATA[{0}]]>", reader->Value ); break; case XmlNodeType::ProcessingInstruction: Console::Write( "<?{0} {1}?>", reader->Name, reader->Value ); break; case XmlNodeType::Comment: Console::Write( "<!--{0}-->", reader->Value ); break; case XmlNodeType::XmlDeclaration: Console::Write( "<?xml version='1.0'?>" ); break; case XmlNodeType::Document: break; case XmlNodeType::DocumentType: Console::Write( "<!DOCTYPE {0} [{1}]", reader->Name, reader->Value ); break; case XmlNodeType::EntityReference: Console::Write( reader->Name ); break; case XmlNodeType::EndElement: Console::Write( "</{0}>", reader->Name ); break; } } } finally { if ( reader != nullptr ) reader->Close(); } }
import System.*;
import System.IO.*;
import System.Xml.*;
public class Sample
{
private static String fileName = "items.xml";
public static void main(String[] args)
{
XmlTextReader reader = null;
try {
// Load the reader with the data file and ignore
//all white space nodes.
reader = new XmlTextReader(fileName);
reader.set_WhitespaceHandling(WhitespaceHandling.None);
// Parse the file and display each of the nodes.
while(reader.Read()) {
switch(reader.get_NodeType() ) {
case XmlNodeType.Element :
Console.Write("<{0}>", reader.get_Name());
break;
case XmlNodeType.Text :
Console.Write(reader.get_Value());
break;
case XmlNodeType.CDATA :
Console.Write("<![CDATA[{0}]]>", reader.get_Value());
break;
case XmlNodeType.ProcessingInstruction :
Console.Write("<?{0} {1}?>", reader.get_Name(),
reader.get_Value());
break;
case XmlNodeType.Comment :
Console.Write("<!--{0}-->", reader.get_Value());
break;
case XmlNodeType.XmlDeclaration :
Console.Write("<?xml version='1.0'?>");
break;
case XmlNodeType.Document :
break;
case XmlNodeType.DocumentType :
Console.Write("<!DOCTYPE {0} [{1}]", reader.get_Name(),
reader.get_Value());
break;
case XmlNodeType.EntityReference :
Console.Write(reader.get_Name());
break;
case XmlNodeType.EndElement :
Console.Write("</{0}>", reader.get_Name());
break;
}
}
}
finally {
if (reader != null) {
reader.Close();
}
}
} //main
} // End class Sample
Nell'esempio viene utilizzato il file items.xml.
<?xml version="1.0"?> <!-- This is a sample XML document --> <!DOCTYPE Items [<!ENTITY number "123">]> <Items> <Item>Test with an entity: &number;</Item> <Item>test with a child element <more/> stuff</Item> <Item>test with a CDATA section <![CDATA[<456>]]> def</Item> <Item>Test with an char entity: A</Item> <!-- Fourteen chars in this element.--> <Item>1234567890ABCD</Item> </Items>
Windows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile per Pocket PC, Windows Mobile per Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
.NET Framework non supporta tutte le versioni di ciascuna piattaforma. Per un elenco delle versioni supportate, vedere Requisiti di sistema.
Nota