簡體   English   中英

無法讀取XML“值”

[英]Can't read XML “value”

我有一些看起來像這樣的XML:

<PackageConstruct900 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <ID>{5209724e-1c5a-4d84-962e-371271c3836c}</ID>
  <ParentID />
  <Name />
  <Type>Package</Type>
  <Tasks>
    <anyType xsi:type="Task">
      <ID>{4c97132c-ba7d-4fba-9b01-333976e9ad22}</ID>
      <ParentID>{E893A7FD-2758-4315-9181-93F8728332E5}</ParentID>
      <Name>ProcessAgility</Name>
      <Type>Task</Type>
      <StartedOn>1900-01-01T00:00:00</StartedOn>
      <EndedOn>1900-01-01T00:00:00</EndedOn>
    </anyType>
  </Tasks>
</PackageConstruct900>

我正在嘗試捕獲第二個“名稱”節點(“ ProcessAgility”)的值。

但是(XmlReader)reader.Value到達此節點時返回一個空字符串。 如何捕獲<nodeName>TEXT</nodeName>

到目前為止,這是我的代碼:

XmlReader reader = XmlReader.Create(pathToFile, settings);

reader.MoveToContent();
while (reader.Read())
{
    switch (reader.NodeType)
    {
        case XmlNodeType.Text:
            break;
        case XmlNodeType.Element:                        
            switch (reader.Name)
            {
                case "anyType":
                    newJob = true;
                    break;
                case "AML":
                    string ss = string.Empty;
                    ss = reader.ReadInnerXml();
                    ss = System.Net.WebUtility.HtmlDecode(ss);
                    rs = XmlReader.Create(ss, settings);
                    break;
                case "Name":
                    if (newJob && reader.HasValue)
                    {
                        jobName = reader.Value;
                    }
                    if (!string.IsNullOrWhiteSpace(jobName))
                    {
                        if (!jobsAdded.Contains(jobName))
                        {
                            jobsAdded.Add(jobName);
                        }
                    }
                    break;
                case "Tasks":
                    m_ConvertingTask = true;
                    break;
                case "TRIGGERS":
                    break;
            }
            break;
    }
}

嘗試使用XmlDocument,然后您可以像這樣使用XPath導航:/ PackageConstruct900 / Tasks / anyType / Name

        XmlDocument doc = new XmlDocument();
        doc.LoadXml("<PackageConstruct900 xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\">\r\n  <ID>{5209724e-1c5a-4d84-962e-371271c3836c}</ID>\r\n  <ParentID />\r\n  <Name />\r\n  <Type>Package</Type>\r\n  <Tasks>\r\n    <anyType xsi:type=\"Task\">\r\n      <ID>{4c97132c-ba7d-4fba-9b01-333976e9ad22}</ID>\r\n      <ParentID>{E893A7FD-2758-4315-9181-93F8728332E5}</ParentID>\r\n      <Name>ProcessAgility</Name>\r\n      <Type>Task</Type>\r\n      <StartedOn>1900-01-01T00:00:00</StartedOn>\r\n      <EndedOn>1900-01-01T00:00:00</EndedOn>\r\n    </anyType>\r\n  </Tasks>\r\n</PackageConstruct900>");
        XmlNode root = doc.DocumentElement;
        XmlNode node = root.SelectSingleNode(
            "/PackageConstruct900/Tasks/anyType/Name");
        Console.WriteLine(node.InnerXml);

這將為您提供第一個節點,如果您想要列表然后對其進行迭代,則可以使用:

        XmlNodeList nodes = root.SelectNodes("/PackageConstruct900/Tasks");
        foreach (XmlNode node in nodes)
        {
            var typename = node.SelectSingleNode("anyType/Name");
            Console.WriteLine(typename.InnerXml);    
        }            

一個非常簡單(非常具體)的System.Xml.Linq.XElement解決方案是:

string processAgility = XElement.Parse(File.ReadAllText(pathToFile))
  .Element("Tasks")
  .Element("anyType")
  .Element("Name")
  .Value;

或者,如果包含using System.Xml.XPath指令,則可以將XPath natigation與XPathSelectElement擴展方法一起使用:

string processAgility = XElement.Parse(File.ReadAllText(pathToFile))
  .XPathSelectElement("Tasks/anyType/Name")
  .Value;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM