使用XmlReader读取XML

时间:2011-11-08 18:04:36

标签: c# xml .net-3.5 xpath xmlreader

我在使用XmlReader读取XML文件时遇到了一些麻烦。我可以打开和关闭文件(我认为),但是当解析我需要的信息时,我有点迷失。这是我需要解析的文件的一部分:

<?xml version="1.0" encoding="UTF-8"?>
<database name="Dictionary">
  <data>
    <Translations>
      <Translation UniversalAbbv="Enu" lang="en" localization="US" unicode="0">
        <Set>
          ...
        </Set>
        <Set>
          ...
        </Set>
        <Set>
          <CaseSensitive value="0" />
          <Enums translate="1">
            <Enum_Entry ENUM_H="STOPRUN_STOP" EnumID="0" EnumString="Stop" SetID="160" />
            <Enum_Entry ENUM_H="STOPRUN_RUN" EnumID="1" EnumString="Run" SetID="160" />
            <Enum_Entry ENUM_H="STOPRUN_HOLD " EnumID="2" EnumString="Hold" SetID="160" />
          </Enums>
          <IncludeFiles_cs name="CSFile" value="StopRun.cs" />
          <IncludeFiles_h name="Header" value="NULL" />
          <IncludeFiles_java name="Java" value="NULL" />
          <SetID value="160" />
          <SetName value="Stop Run" />
          <TwoSet ENUM_H="STOPRUN_ENUM_SET" />
        </Set>
        <Set>
          ...
        </Set>
   </Translation>
  </Translations>
  </data>
</database>

我需要找到EnumID="0"EnumID="1"(或"STOPRUN_STOP""STOPRUN_RUN")的位置,并分别取出"Stop""Run"字符串。这是我到目前为止的代码:

static class Dictionary
{
    static private XmlReader Reader = null;

    static public void Open()
    {
        XML_Generator.Dictionary.Reader = XmlReader.Create(XML_Generator.Program.DictionaryFilename);
    }

    static public void Close()
    {
        XML_Generator.Dictionary.Reader.Close();
    }

    static public void Read()
    {
        while (Reader.Read())
        {
            Trace.TraceInformation(XML_Generator.Dictionary.Reader.ReadElementContentAsString()); // <-- This throw an error. :(
        }
    }
}

我知道这并不多,但我对这个问题有点失落。任何帮助,将不胜感激。感谢。

1 个答案:

答案 0 :(得分:1)

以下是使用XML Reader

读取xml文件的示例
   int intCount = 0;
    XmlReaderSettings objSettings = new XmlReaderSettings();
    objSettings.IgnoreWhitespace = true;
    objSettings.IgnoreComments = true;
    string booksFile = Server.MapPath("books.xml");
    using (XmlReader objReader = XmlReader.Create(booksFile, objSettings))
    {
        while (objReader.Read())
        {
            if (objReader.NodeType == XmlNodeType.Element && "Book" == objReader.LocalName)
            {
                 intCount++;
            }
            if (objReader.NodeType ==XmlNodeType.Text )
            {
                Response.Write("<BR />" + objReader.Value);
            }
        }
    }
    Response.Write(String.Format("<BR /><BR /><BR /><b> Total {0} books.</b>", intCount));