可以';t使用XElement检索XML元素的值

本文关键字:XML 检索 元素 XElement 使用 可以 | 更新日期: 2023-09-27 18:22:17

我正试图从通过文件浏览器提供的XML文件中读取,但即使我可以看到XML文件进入元素,值也始终为null。

  public void UploadXml(Stream fileStream)
  {
    //Load xml
      fileStream.Position = 0;
      var xdoc = XElement.Load(fileStream);
      IEnumerable<XElement> elements = xdoc.Elements();
      var codeList = new CodeList();
      foreach (var item in elements)
      {
          codeList.Name = item.Element("CODELIST_NAME").Value;
          codeList.Description = item.Element("DESRIPTION").Value;
          codeList.Version = item.Element("VERSION").Value;
          codeList.EffectiveDate = DateTime.Parse(item.Element("EFFECTIVE_DATE").Value);
          codeList.ExpirationDate = DateTime.Parse(item.Element("EXPIRATION_DATE").Value);
      }
      // save code list
      // get code list ID
      // create codes
  }

更新XML

<?xml version="1.0" encoding="utf-8"?>
<CONTEXT xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
         xmlns:xsd="http://www.w3.org/2001/XMLSchema"    
         xmlns="http://www.w3.org/2000/xmlns">
  <CONTEXT_NAME></CONTEXT_NAME>
  <CODELIST>
    <CODELIST_NAME></CODELIST_NAME>
        <DESRIPTION></DESRIPTION>
        <VERSION></VERSION>
        <USERNAME>test user</USERNAME>
        <OWNER_TEAM />
        <STEWARD_TEAM />
        <STATUS></STATUS>
        <LAST_MODIFIED></LAST_MODIFIED>
        <LAST_MODIFIED_NAME></LAST_MODIFIED_NAME>
        <EFFECTIVE_DATE></EFFECTIVE_DATE>
        <EXPIRATION_DATE></EXPIRATION_DATE>
        <FILE_TIMESTAMP></FILE_TIMESTAMP>
       <CONSTRAINED_VALUE>
           <CODE></CODE>
           <PARENT_ID />
           <NAME></NAME>
           <DESCRIPTION></DESCRIPTION>
       </CONSTRAINED_VALUE>
 </CODELIST>
</CONTEXT>

在一个正常的文件中,文件中会有数据,显然我只需要为示例删除它。

对于数据库中的行,将重复使用受约束的值标记

可以';t使用XElement检索XML元素的值

您需要指定(默认)命名空间。

  var xdoc = XElement.Load(fileStream);
  var dns = xdoc.GetDefaultNamespace();
  ....

然后你的循环就变成了(添加了一些范围修正)

  foreach (var item in elements)
  {
      var codeList = new CodeList();
      codeList.Name = item.Element(dns + "CODELIST_NAME").Value;
      codeList.Description = item.Element(dns + "DESRIPTION").Value;
      codeList.Version = item.Element(dns + "VERSION").Value;
      codeList.EffectiveDate = DateTime.Parse(item.Element(dns + "EFFECTIVE_DATE").Value);
      codeList.ExpirationDate = DateTime.Parse(item.Element(dns + "EXPIRATION_DATE").Value);
      // save code list
  }

在中

IEnumerable<XElement> elements = xdoc.Elements();

定义要解析的元素的父元素。例如,如果您的xml类似于:

<parent>
    <CODELIST_NAME></CODELIST_NAME>
    <DESRIPTION></DESRIPTION>
    <VERSION></VERSION>
    <EFFECTIVE_DATE></EFFECTIVE_DATE>
    <EXPIRATION_DATE></EXPIRATION_DATE>
</parent>

然后写为

IEnumerable<XElement> elements = xdoc.Elements("parent");

Giannis

我知道你找到了答案,但我想把我所做的一切放在正确的功能上,只是为了好玩:)这是我使用的代码:

using System;
using System.Xml;
using System.Xml.Linq;
namespace xmlTesting
{
  public class codeList
  {
    public string Name { get; set; }
    public string Description { get; set; }
    public string Version { get; set; }
    public DateTime EffectiveDate { get; set; }
    public DateTime ExpirationDate { get; set; }
  }
  class program {
    static void Main(string[] args)
    {
      var CL = UploadXml(XElement.Load(@"c:'debug'xmlcontent.xml"));
      Console.WriteLine(
        string.Format("name: {0}'nDesc: {1}'nVersion: {2}'nEffectivdate: {3}'nExp: {4}"
        , CL.Name, CL.Description, CL.Version, CL.EffectiveDate, CL.ExpirationDate)
        );
      Console.ReadKey(true);
    }
    public static codeList UploadXml(XElement xdoc)
    {
      var codeList = new codeList();
      foreach (XElement XE in xdoc.Descendants())
      {
        switch (XE.Name.LocalName)
        {
          case "CODELIST_NAME":
            codeList.Name = XE.Value;
            break;
          case "DESCRIPTION":
            if(codeList.Description == null)
            codeList.Description = XE.Value;
            break;
          case "VERSION":
            codeList.Version = XE.Value;
            break;
          case "EFFECTIVE_DATE":
            codeList.EffectiveDate = DateTime.Parse(XE.Value);
            break;
          case "EXPIRATION_DATE":
            codeList.ExpirationDate = DateTime.Parse( XE.Value);
            break;
        }
      }
      // save code list
      // get code list ID
      // create codes
      return codeList;
    }
  }
}

我使用的xml是这样的。

<?xml version="1.0" encoding="utf-8"?>
<CONTEXT xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
         xmlns:xsd="http://www.w3.org/2001/XMLSchema"    
         xmlns="http://www.w3.org/2000/xmlns">
  <CONTEXT_NAME></CONTEXT_NAME>
  <CODELIST>
    <CODELIST_NAME>a name</CODELIST_NAME>
        <DESCRIPTION>a desr</DESCRIPTION>
        <VERSION>test1.1</VERSION>
        <USERNAME>test user</USERNAME>
        <OWNER_TEAM />
        <STEWARD_TEAM />
        <STATUS></STATUS>
        <LAST_MODIFIED>a day</LAST_MODIFIED>
        <LAST_MODIFIED_NAME>trae</LAST_MODIFIED_NAME>
        <EFFECTIVE_DATE>07/05/1983</EFFECTIVE_DATE>
        <EXPIRATION_DATE>07/05/1983</EXPIRATION_DATE>
        <FILE_TIMESTAMP></FILE_TIMESTAMP>
       <CONSTRAINED_VALUE>
           <CODE></CODE>
           <PARENT_ID />
           <NAME></NAME>
           <DESCRIPTION></DESCRIPTION>
       </CONSTRAINED_VALUE>
 </CODELIST>
</CONTEXT>

感谢您的帮助,修复这个对我很有用

我的问题在于我如何解读价值观。

xdoc.Element(XName.Get("CODELIST", dns.NamespaceName)).Element(XName.Get("CODELIST_NAME", dns.NamespaceName)).Value,

以这种方式阅读它已经为我修复了它。