閱讀英文

共用方式為


XmlNodeReader 類別

定義

表示讀取器,其提供對 XmlNode 中 XML 資料的快速且非快取順向存取。

public class XmlNodeReader : System.Xml.XmlReader, System.Xml.IXmlNamespaceResolver
public class XmlNodeReader : System.Xml.XmlReader
繼承
XmlNodeReader
實作

範例

在下列範例中,會將 XML 檔案載入至 XML 文件,並進行修改。 將 XML 文件傳遞至 XmlNodeReader,其稍後會傳遞至 XmlReader.Create 方法。 當驗證讀取器剖析檔案時,其可驗證對 XML 檔案所做的任何變更。

using System;
using System.Xml;
using System.Xml.Schema;
using System.IO;

public class Sample {

  public static void Main() {

    // Create and load the XML document.
    XmlDocument doc = new XmlDocument();
    doc.Load("booksSchema.xml");

    // Make changes to the document.
    XmlElement book = (XmlElement) doc.DocumentElement.FirstChild;
    book.SetAttribute("publisher", "Worldwide Publishing");

    // Create an XmlNodeReader using the XML document.
    XmlNodeReader nodeReader = new XmlNodeReader(doc);

    // Set the validation settings on the XmlReaderSettings object.
    XmlReaderSettings settings = new XmlReaderSettings();
    settings.ValidationType = ValidationType.Schema;
    settings.Schemas.Add("urn:bookstore-schema", "books.xsd");
    settings.ValidationEventHandler += new ValidationEventHandler (ValidationCallBack);

   // Create a validating reader that wraps the XmlNodeReader object.
   XmlReader reader = XmlReader.Create(nodeReader, settings);

   // Parse the XML file.
   while (reader.Read());
  }

  // Display any validation errors.
  private static void ValidationCallBack(object sender, ValidationEventArgs e) {
    Console.WriteLine("Validation Error: {0}", e.Message);
  }
}

下列兩個 XML 檔案會當做輸入使用。

<?xml version='1.0'?>
<bookstore xmlns="urn:bookstore-schema">
  <book genre="autobiography">
    <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">
    <title>The Confidence Man</title>
    <author>
      <first-name>Herman</first-name>
      <last-name>Melville</last-name>
    </author>
    <price>11.99</price>
  </book>
</bookstore>
<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema"
    xmlns="urn:bookstore-schema"
    elementFormDefault="qualified"
    targetNamespace="urn:bookstore-schema">

 <xsd:element name="bookstore" type="bookstoreType"/>

 <xsd:complexType name="bookstoreType">
  <xsd:sequence maxOccurs="unbounded">
   <xsd:element name="book"  type="bookType"/>
  </xsd:sequence>
 </xsd:complexType>

 <xsd:complexType name="bookType">
  <xsd:sequence>
   <xsd:element name="title" type="xsd:string"/>
   <xsd:element name="author" type="authorName"/>
   <xsd:element name="price"  type="xsd:decimal"/>
  </xsd:sequence>
  <xsd:attribute name="genre" type="xsd:string"/>
 </xsd:complexType>

 <xsd:complexType name="authorName">
  <xsd:sequence>
   <xsd:element name="first-name"  type="xsd:string"/>
   <xsd:element name="last-name" type="xsd:string"/>
  </xsd:sequence>
 </xsd:complexType>

</xsd:schema>

輸出:

驗證錯誤:未宣告 'publisher' 屬性。

備註

注意

建議您使用 類別和 Create 方法,而不是使用 XmlNodeReaderXmlReaderSettings 來建立XmlReader實例。 這可讓您利用 XML 1.0 建議的一致性檢查和合規性。

XmlNodeReader能夠讀取 XML DOM 子樹。 這個類別不支援 DTD) 或架構驗證 (檔案類型定義。 不過,您可以建立 XmlReader 對象來包裝 XmlNodeReader 物件,以驗證儲存在 對象中的數據 XmlNodeReader ,如範例一節所示。

建構函式

XmlNodeReader(XmlNode)

使用指定的 XmlNode 來建立 XmlNodeReader 類別的執行個體。

屬性

AttributeCount

取得目前節點的屬性數目。

BaseURI

取得目前節點的基底 (Base) URI。

CanReadBinaryContent

取得值,這個值表示 XmlNodeReader 是否會實作二進位內容讀取方法。

CanReadBinaryContent

取得值,這個值表示 XmlReader 是否會實作二進位內容讀取方法。

(繼承來源 XmlReader)
CanReadValueChunk

取得值,表示 XmlReader 是否會實作 ReadValueChunk(Char[], Int32, Int32) 方法。

(繼承來源 XmlReader)
CanResolveEntity

取得值,指出這個讀取器是否可以剖析和解析實體。

Depth

取得 XML 文件中目前節點的深度。

EOF

取得值,表示讀取器是否位於資料流結尾。

HasAttributes

取得值,表示目前節點是否具有任何屬性。

HasValue

取得值,表示目前節點是否具有 Value

IsDefault

取得值,表示目前的節點是否為文件類型定義 (DTD),或結構描述中定義之預設值所產生的屬性。

IsEmptyElement

取得值,指出目前節點是否為空白元素 (,例如) <MyElement/>

Item[Int32]

取得具有指定索引的屬性值。

Item[Int32]

在衍生類別中覆寫時,取得具有指定索引的屬性值。

(繼承來源 XmlReader)
Item[String, String]

取得具有指定的區域名稱和命名空間 URI 的屬性值。

Item[String, String]

在衍生類別中覆寫時,取得具有指定 LocalNameNamespaceURI 的屬性值。

(繼承來源 XmlReader)
Item[String]

在衍生類別中覆寫時,取得具有指定名稱的屬性值。

Item[String]

在衍生類別中覆寫時,取得具有指定 Name 的屬性值。

(繼承來源 XmlReader)
LocalName

取得目前節點的區域名稱。

Name

取得目前節點的限定名稱 (Qualified Name)。

NamespaceURI

取得讀取器所在節點的命名空間 URI (如 W3C 命名空間規格中所定義)。

NameTable

取得與這個實作關聯的 XmlNameTable

NodeType

取得目前節點的類型。

Prefix

取得與目前節點相關聯的命名空間前置詞。

QuoteChar

取得用來括住屬性節點值的引號字元。

QuoteChar

在衍生類別中覆寫時,取得用來括住屬性節點值的引號字元。

(繼承來源 XmlReader)
ReadState

取得讀取器的狀態。

SchemaInfo

取得已指派給目前節點的結構描述資訊。

SchemaInfo

取得在結構描述驗證之後已指派給目前節點的結構描述資訊。

(繼承來源 XmlReader)
Settings

取得 XmlReaderSettings 物件,用於建立這個 XmlReader 執行個體。

(繼承來源 XmlReader)
Value

取得目前節點的文字值。

ValueType

取得目前節點的 Common Language Runtime (CLR) 型別。

(繼承來源 XmlReader)
XmlLang

取得目前的 xml:lang 範圍。

XmlSpace

取得目前的 xml:space 範圍。

方法

Close()

ReadState 變更為 Closed

Dispose()

釋放 XmlReader 類別目前的執行個體所使用的全部資源。

(繼承來源 XmlReader)
Dispose(Boolean)

釋放 XmlReader 所使用的 Unmanaged 資源,並選擇性地釋放 Managed 資源。

(繼承來源 XmlReader)
Equals(Object)

判斷指定的物件是否等於目前的物件。

(繼承來源 Object)
GetAttribute(Int32)

取得具有指定索引的屬性值。

GetAttribute(String)

取得具有指定名稱的屬性值。

GetAttribute(String, String)

取得具有指定的區域名稱和命名空間 URI 的屬性值。

GetHashCode()

做為預設雜湊函式。

(繼承來源 Object)
GetType()

取得目前執行個體的 Type

(繼承來源 Object)
GetValueAsync()

非同步取得目前節點的值。

(繼承來源 XmlReader)
IsStartElement()

呼叫 MoveToContent() 並測試目前的內容節點為開頭標記或空白項目標記。

(繼承來源 XmlReader)
IsStartElement(String)

呼叫 MoveToContent() 並測試目前的內容節點為開頭標記或空白項目標記,以及所找到項目的 Name 屬性是否符合指定的引數。

(繼承來源 XmlReader)
IsStartElement(String, String)

呼叫 MoveToContent() 並測試目前的內容節點為開頭標記或空白項目標記,以及所找到項目的 LocalNameNamespaceURI 屬性是否符合指定的字串。

(繼承來源 XmlReader)
LookupNamespace(String)

解析目前項目範圍中的命名空間前置詞。

MemberwiseClone()

建立目前 Object 的淺層複製。

(繼承來源 Object)
MoveToAttribute(Int32)

移至具有指定索引的屬性。

MoveToAttribute(String)

移至具有指定名稱的屬性。

MoveToAttribute(String, String)

移至具有指定的區域名稱和命名空間 URI 的屬性。

MoveToContent()

檢查目前節點是否為內容 (非空白字元文字、CDATAElementEndElementEntityReferenceEndEntity) 節點。 如果節點並非內容節點,讀取器會先跳至下一個內容節點或檔案結尾。 它會略過下列型別的節點:ProcessingInstructionDocumentTypeCommentWhitespaceSignificantWhitespace

(繼承來源 XmlReader)
MoveToContentAsync()

非同步檢查目前節點是否為內容節點。 如果節點並非內容節點,讀取器會先跳至下一個內容節點或檔案結尾。

(繼承來源 XmlReader)
MoveToElement()

移至包含目前屬性節點的項目。

MoveToFirstAttribute()

移至第一個屬性。

MoveToNextAttribute()

移至下一個屬性。

Read()

從資料流讀取下一個節點。

ReadAsync()

非同步讀取資料流中的下一個節點。

(繼承來源 XmlReader)
ReadAttributeValue()

將屬性值剖析成一或多個 TextEntityReferenceEndEntity 節點。

ReadContentAs(Type, IXmlNamespaceResolver)

以指定型别的物件形式讀取內容。

(繼承來源 XmlReader)
ReadContentAsAsync(Type, IXmlNamespaceResolver)

以非同步的方式讀取做為指定型别之物件的內容。

(繼承來源 XmlReader)
ReadContentAsBase64(Byte[], Int32, Int32)

讀取內容,並傳回 Base64 已解碼的二進位位元組。

ReadContentAsBase64(Byte[], Int32, Int32)

讀取內容,並傳回 Base64 已解碼的二進位位元組。

(繼承來源 XmlReader)
ReadContentAsBase64Async(Byte[], Int32, Int32)

以非同步的方式讀取內容,並傳回 Base64 已解碼的二進位位元組。

(繼承來源 XmlReader)
ReadContentAsBinHex(Byte[], Int32, Int32)

讀取內容,並傳回 BinHex 已解碼的二進位資料。

ReadContentAsBinHex(Byte[], Int32, Int32)

讀取內容,並傳回 BinHex 已解碼的二進位位元組。

(繼承來源 XmlReader)
ReadContentAsBinHexAsync(Byte[], Int32, Int32)

以非同步的方式讀取內容,並傳回 BinHex 的解碼二進位位元組。

(繼承來源 XmlReader)
ReadContentAsBoolean()

Boolean 的形式,讀取目前位置的文字內容。

(繼承來源 XmlReader)
ReadContentAsDateTime()

DateTime 物件的形式,讀取目前位置的文字內容。

(繼承來源 XmlReader)
ReadContentAsDateTimeOffset()

DateTimeOffset 物件的形式,讀取目前位置的文字內容。

(繼承來源 XmlReader)
ReadContentAsDecimal()

Decimal 物件的形式,讀取目前位置的文字內容。

(繼承來源 XmlReader)
ReadContentAsDouble()

以雙精確度浮點數的形式讀取目前位置的文字內容。

(繼承來源 XmlReader)
ReadContentAsFloat()

以單精確度浮點數的形式讀取目前位置的文字內容。

(繼承來源 XmlReader)
ReadContentAsInt()

以 32 位元帶正負號之整數的形式讀取目前位置的文字內容。

(繼承來源 XmlReader)
ReadContentAsLong()

以 64 位元帶正負號之整數的形式讀取目前位置的文字內容。

(繼承來源 XmlReader)
ReadContentAsObject()

Object 的形式,讀取目前位置的文字內容。

(繼承來源 XmlReader)
ReadContentAsObjectAsync()

以非同步方式與 Object 的形式,讀取目前位置的文字內容。

(繼承來源 XmlReader)
ReadContentAsString()

String 物件的形式,讀取目前位置的文字內容。

(繼承來源 XmlReader)
ReadContentAsStringAsync()

以非同步方式與 String 物件的形式,讀取目前位置的文字內容。

(繼承來源 XmlReader)
ReadElementContentAs(Type, IXmlNamespaceResolver)

以要求之型別的形式讀取項目內容。

(繼承來源 XmlReader)
ReadElementContentAs(Type, IXmlNamespaceResolver, String, String)

檢查指定的區域名稱和命名空間 URI 是否與目前的項目相符,然後以要求之型別的形式讀取項目內容。

(繼承來源 XmlReader)
ReadElementContentAsAsync(Type, IXmlNamespaceResolver)

以要求之型別的形式,非同步讀取項目內容。

(繼承來源 XmlReader)
ReadElementContentAsBase64(Byte[], Int32, Int32)

讀取項目,並將 Base64 內容解碼。

ReadElementContentAsBase64(Byte[], Int32, Int32)

讀取項目,並將 Base64 內容解碼。

(繼承來源 XmlReader)
ReadElementContentAsBase64Async(Byte[], Int32, Int32)

以非同步的方式讀取項目,並將 Base64 內容解碼。

(繼承來源 XmlReader)
ReadElementContentAsBinHex(Byte[], Int32, Int32)

讀取項目,並將 BinHex 內容解碼。

ReadElementContentAsBinHex(Byte[], Int32, Int32)

讀取項目,並將 BinHex 內容解碼。

(繼承來源 XmlReader)
ReadElementContentAsBinHexAsync(Byte[], Int32, Int32)

以非同步的方式讀取項目,並將 BinHex 內容解碼。

(繼承來源 XmlReader)
ReadElementContentAsBoolean()

Boolean 物件的形式,讀取目前項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsBoolean(String, String)

檢查指定的區域名稱和命名空間 URI 是否與目前的項目相符,然後以 Boolean 物件的形式,讀取目前的項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsDateTime()

DateTime 物件的形式,讀取目前項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsDateTime(String, String)

檢查指定的區域名稱和命名空間 URI 是否與目前的項目相符,然後以 DateTime 物件的形式,讀取目前的項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsDecimal()

Decimal 物件的形式,讀取目前項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsDecimal(String, String)

檢查指定的區域名稱和命名空間 URI 是否與目前的項目相符,然後以 Decimal 物件的形式,讀取目前的項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsDouble()

以雙精確度浮點數的形式,讀取目前的項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsDouble(String, String)

檢查指定的區域名稱和命名空間 URI 是否與目前的項目相符,然後以雙精確度浮點數的形式,讀取目前的項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsFloat()

以單精確度浮點數的形式,讀取目前的項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsFloat(String, String)

檢查指定的區域名稱和命名空間 URI 是否與目前的項目相符,然後以單精確度浮點數的形式,讀取目前的項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsInt()

以 32 位元帶正負號之整數的形式,讀取目前的項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsInt(String, String)

檢查指定的區域名稱和命名空間 URI 是否與目前的項目相符,然後以 32 位元帶正負號之整數的形式,讀取目前的項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsLong()

以 64 位元帶正負號之整數的形式讀取目前的元素並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsLong(String, String)

檢查指定的區域名稱和命名空間 URI 是否與目前的項目相符,然後以 64 位元帶正負號之整數的形式讀取目前的元素並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsObject()

Object 的形式,讀取目前項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsObject(String, String)

檢查指定的區域名稱和命名空間 URI 是否與目前的項目相符,然後以 Object 的形式,讀取目前的項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsObjectAsync()

以非同步方式與 Object 的形式,讀取目前項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsString()

String 物件的形式,讀取目前項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsString(String, String)

檢查指定的區域名稱和命名空間 URI 是否與目前的項目相符,然後以 String 物件的形式,讀取目前的項目並傳回內容。

(繼承來源 XmlReader)
ReadElementContentAsStringAsync()

以非同步方式與 String 物件的形式,讀取目前項目並傳回內容。

(繼承來源 XmlReader)
ReadElementString()

讀取純文字項目。 不過,我們建議您改用ReadElementContentAsString()方法相反地,因為它會提供較簡單的方式來處理這項作業。

(繼承來源 XmlReader)
ReadElementString(String)

檢查Name屬性找到的項目之前讀取純文字的項目符合指定的字串。 不過,我們建議您改用ReadElementContentAsString()方法相反地,因為它會提供較簡單的方式來處理這項作業。

(繼承來源 XmlReader)
ReadElementString(String, String)

檢查LocalNameNamespaceURI項目的屬性找到符合的指定的字串之前讀取純文字的項目。 不過,我們建議您改用ReadElementContentAsString(String, String)方法相反地,因為它會提供較簡單的方式來處理這項作業。

(繼承來源 XmlReader)
ReadEndElement()

檢查目前節點為結尾標記,並使讀取器前進至下一個節點。

(繼承來源 XmlReader)
ReadInnerXml()

在衍生類別中覆寫時,將所有的內容當做字串讀取,包括標記。

(繼承來源 XmlReader)
ReadInnerXmlAsync()

以字串形式非同步讀取所有內容,包括標記。

(繼承來源 XmlReader)
ReadOuterXml()

在衍生類別中覆寫時,讀取代表這個節點及其所有子節點的內容,包括標記。

(繼承來源 XmlReader)
ReadOuterXmlAsync()

非同步讀取表示這個節點及其所有子系的內容,包括標記。

(繼承來源 XmlReader)
ReadStartElement()

檢查以確定目前節點為項目,然後使讀取器前進至下一個節點。

(繼承來源 XmlReader)
ReadStartElement(String)

檢查目前的內容節點是否具有的項目指定Name並使讀取器前進至下一個節點。

(繼承來源 XmlReader)
ReadStartElement(String, String)

檢查目前的內容節點是否具有的項目指定LocalNameNamespaceURI並使讀取器前進至下一個節點。

(繼承來源 XmlReader)
ReadString()

將項目或文字節點的內容當做字串讀取。

ReadSubtree()

傳回新XmlReader可以用來讀取目前的節點及其所有子系的執行個體。

(繼承來源 XmlReader)
ReadToDescendant(String)

往前推進XmlReader下一個子系的項目,具有指定限定名稱。

(繼承來源 XmlReader)
ReadToDescendant(String, String)

往前推進XmlReader下一個子系的項目,使用指定的區域名稱和命名空間 URI。

(繼承來源 XmlReader)
ReadToFollowing(String)

在找到具有指定限定名稱的項目之前讀取。

(繼承來源 XmlReader)
ReadToFollowing(String, String)

在找到具有指定區域名稱和命名空間 URI 的項目之前讀取。

(繼承來源 XmlReader)
ReadToNextSibling(String)

往前推進XmlReader指定限定名稱的下一個同層級項目。

(繼承來源 XmlReader)
ReadToNextSibling(String, String)

XmlReader 前移到下一個具有指定區域名稱和命名空間 URI 的同層級項目。

(繼承來源 XmlReader)
ReadValueChunk(Char[], Int32, Int32)

讀取 XML 文件中內嵌之大量文字資料流。

(繼承來源 XmlReader)
ReadValueChunkAsync(Char[], Int32, Int32)

以非同步的方式讀取 XML 文件中內嵌之大量文字資料流。

(繼承來源 XmlReader)
ResolveEntity()

解析 EntityReference 節點的實體參考。

Skip()

略過目前節點的子節點。

SkipAsync()

以非同步的方式略過目前節點的子節點。

(繼承來源 XmlReader)
ToString()

傳回代表目前物件的字串。

(繼承來源 Object)

明確介面實作

IDisposable.Dispose()

如需這個成員的說明,請參閱 Dispose()

(繼承來源 XmlReader)
IXmlNamespaceResolver.GetNamespacesInScope(XmlNamespaceScope)

如需這個成員的說明,請參閱 GetNamespacesInScope(XmlNamespaceScope)

IXmlNamespaceResolver.LookupNamespace(String)

如需這個成員的說明,請參閱 LookupNamespace(String)

IXmlNamespaceResolver.LookupPrefix(String)

如需這個成員的說明,請參閱 LookupPrefix(String)

適用於

產品 版本
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1