Home >Backend Development >C#.Net Tutorial >Easily process XML data in .NET Framework (1-2)

Easily process XML data in .NET Framework (1-2)

黄舟
黄舟Original
2016-12-20 14:02:571256browse

?XmlReader class

??XML browser supports a programming interface, which is used to connect to XML documents and "pull out" the data you want. If you understand the browser more deeply, you will find that the browser works similarly to how our desktop applications retrieve data from the database. The database service returns a cursor object that contains all query result sets and returns a reference to the starting address of the target data set. The client of the XML browser receives a reference to the browser instance. This example extracts the underlying data stream and displays the retrieved data as an XML tree. The browser class provides a read-only, forward cursor. You can use the methods provided by the browser class to rotate the cursor and traverse each piece of data in the result set.

??The XML document viewed from the browser is not a tagged text file, but a serialized node aggregation. It is a special cursor mode in the .NET Framework; you cannot find any other similar API function in the .NET Framework.

??There are several differences between browsers and XMLDOM parsers. The XML browser is enter-only. It has no concepts of parent, child, ancestor, and sibling nodes, and it is read-only. In the .NET Framework, reading and writing XML documents is divided into two completely different functions, which are completed by the XmlReader and XmlWriter classes respectively. To edit XML documents, you can use an XMLDOM parser, or you can design a class yourself to achieve these two functions. Let's start analyzing the program functions of the browser.

??XmlReader is an abstract class, you can extend and extend its functionality. User programs are generally based on the following three categories: XmlTextReader, XmlValidatingReader or XmlNodeReader class. All these classes have the properties shown in Figure 1 and the methods shown in Figure 2. It should be noted that the values ​​​​of some properties are actually attached to an actual browser class, and different classes may be different from the base class. Therefore, the explanation of each attribute in Figure 1 is based on the base class. For example, the CanResolveEntity property only returns true in the XmlValidatingReader class; but it can be set to false in other browser classes. Likewise, the actual return values ​​of some of the methods in Figure 2 may differ for different classes. For example, if the node type is not an element node, the return value type of all methods containing Atrributes is void.

??The XmlTextReader class uses forward-only and read-only methods to quickly access XML data streams. The browser first verifies whether the XML document is well-formed, and if not, throws an exception. XmlTextReader checks that the DTD is well-formed, but does not apply the DTD to validate the document. XmlTextReader loads the XML document by its file name, its URL, or from a file stream, and then quickly processes the XML document data. If you need to validate the document's data, you can use the XmlValidatingReader class.

??You can create instances of the XmlTextReader class in a variety of ways, loading files from the hard disk, loading from URL addresses, loading from streams, and reading XML document data from text:

? ?XmlTextReader reader = new XmlTextReader(file);

??Note that all public structural functions of the XmlTextReader class require you to specify the data source. The data source can be a stream, a file or other. The default structure function of XmlTextReader is protected, so it cannot be applied directly. Like all browser classes in the .NET Framework (such as the SqlDataReader class), once the browser object is connected and opened, you can use the Read method to access the data. At the beginning, we can only use the Read method to move the pointer to the first element; then we can use the Read method or other methods (such as Skip, MoveToContent and ReadInnerXml) to move the pointer to the next node element. To process the content of the entire XML document, you can use a loop to traverse the document content based on the return value of the Read method. Since the Read method returns a Boolean value, when the end node of the document is read, the Read method returns false, otherwise it returns true.



??Figure 3 Outputting an XML Document Node Layout

??string GetXmlFileNodeLayout(string file)
??{
??// Create an XmlTextReader class to point it to the target XML document
??XmlTextReader reader = new XmlTextReader(file);

??// Loop out the text of the node and put it into the StringWriter object instance
??StringWriter writer = new StringWriter();
??string tabPrefix = '';

??while ( reader.Read())
??{
??// Write the opening tag, if the node type is an element
??if (reader.NodeType == XmlNodeType.Element)
??{
??//According to the element At the depth of the node, add reader.Depth tab characters, and then write the element name into <>.
??tabPrefix = new string('t', reader.Depth);
??writer.WriteLine('{0}<{1}>', tabPrefix, reader.Name);
??}
? ?else
??{
??//Write the end tag, if the node type is an element
??if (reader.NodeType == XmlNodeType.EndElement)
??{
??tabPrefix = new string('t', reader.Depth);
??writer.WriteLine('{0}', tabPrefix, reader.Name);
??}
??}
??}

??//Output to the screen
??string buf = writer.ToString( );
??writer.Close();

??// closed flow
??reader.Close();

??return buf; Function for outputting the node elements of a given XML document. This function first opens an XML document, and then uses a loop to process all the contents of the XML document. Each time the Read method is called, the browser's pointer moves down one node. In most cases, the Read method can handle element nodes, but sometimes, when you move from one node to the next, you may be moving between two different types of nodes. But the Read method cannot move between attribute nodes. The browser's MoveToContent method allows the pointer to jump from the head node position to the first content node position. You can also use the Skip method to move the pointer in ProcessingInstruction, DocumentType, Comment, Whitespace and SignificantWhitespace type nodes.

The above is the content of easily processing XML data (1-2) in .NET Framework. For more related content, please pay attention to the PHP Chinese website (www.php.cn)!



Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn