1
<Reports>
  <Databases>
    <Database>Axxest</Database>
    <Database>Axxest2</Database>
  </Databases>
</Reports>

如何阅读AxxestAxxest2使用 c# 来读取这样的 xml 文件?

我试试这个:

XmlDocument xld = new XmlDocument();
xld.Load(XmlPath);
XmlNodeList xnl = xld.SelectSingleNode("Reports").ChildNodes;
tableList.Clear();
foreach (XmlNode xn in xnl)
{
    tableList.Add(xn.InnerText);
} 

但是有什么问题吗?

4

3 回答 3

1

尝试SelectNodes方法和XPath

XmlDocument xld = new XmlDocument();
xld.Load(XmlPath);
XmlNodeList xnl = xld.SelectNodes("Reports/Databases/Database");
foreach (XmlNode xn in xnl)
{
    tableList.Add(xn.InnerText);
}
于 2012-09-17T08:16:21.657 回答
0

请参阅文档的示例

StringBuilder output = new StringBuilder();

String xmlString =
        @"<?xml version='1.0'?>
        <!-- This is a sample XML document -->
        <Items>
          <Item>test with a child element <more/> stuff</Item>
        </Items>";
// Create an XmlReader
using (XmlReader reader = XmlReader.Create(new StringReader(xmlString)))
{
    XmlWriterSettings ws = new XmlWriterSettings();
    ws.Indent = true;
    using (XmlWriter writer = XmlWriter.Create(output, ws))
    {

        // Parse the file and display each of the nodes.
        while (reader.Read())
        {
            switch (reader.NodeType)
            {
                case XmlNodeType.Element:
                    writer.WriteStartElement(reader.Name);
                    break;
                case XmlNodeType.Text:
                    writer.WriteString(reader.Value);
                    break;
                case XmlNodeType.XmlDeclaration:
                case XmlNodeType.ProcessingInstruction:
                    writer.WriteProcessingInstruction(reader.Name, reader.Value);
                    break;
                case XmlNodeType.Comment:
                    writer.WriteComment(reader.Value);
                    break;
                case XmlNodeType.EndElement:
                    writer.WriteFullEndElement();
                    break;
            }
        }

    }
}
OutputTextBlock.Text = output.ToString();
于 2012-09-17T07:57:28.680 回答
0

如果你想在一个 xml 文件中找到一些节点,你可以使用 XPath 进行查询,这就是你在w3 school中所需要的。

如果你调试代码,你会发现xnl的计数是1,它只包括“Databases”节点。“SelectSingleNode”表示选择一个节点,在您的代码中,首先选择“Reports”,然后返回其子节点,其中仅包含“Databases”。您可以尝试 Ria 的代码,使用 SelectNodes 而不是 SelectSingleNode。但是你仍然可以使用“SelectSingleNode”,试试这个:

XmlNodeList xnl = xld.SelectSingleNode("Reports/Databases").ChildNodes;  

希望对你有帮助。

于 2012-09-17T09:49:14.913 回答