使用命名空间和重复节点读取XML

时间:2018-02-22 17:16:26

标签: c# xml

我有以下XML:

<resource>
  <description>TTT</description>
  <title>TEST</title>
  <entity xmlns="TdmBLRuPlUz.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xlink="http://www.w3.org/1999/xlink" xsi:schemaLocation="TdmBLRuPlUz.xsd TdmBLRuPlUz.xsd">
    <UzdProd>
      <row>
        <F_DAUDZ>50</F_DAUDZ>
        <BR_DAUDZ/>
        <DAUDZ>50</DAUDZ>
        <U_DAUDZ/>
        <NKODS>ST2.0_014_023</NKODS>
      </row>
    </UzdProd>
    <UzdMat>
      <row>
        <NKODS>SAG 2.0_014_150</NKODS>
        <NNOSAUK>Sagatave 2.0mm*0.14*150m</NNOSAUK>
        <PK_VIEN>1</PK_VIEN>
        <DAUDZ>0.077</DAUDZ>
        <F_DAUDZ>0.077</F_DAUDZ>
      </row>
    </UzdMat>
  </entity>
</resource>

这是我的C#代码:

XNamespace ns = "TdmBLRuPlUz.xsd";
XDocument doc = XDocument.Parse(xml);

foreach (XElement element in doc.Descendants(ns + "row"))
{
    Console.WriteLine(element.Element(ns + "NKODS").Value);
    string NKODS = element.Element(ns + "NKODS").Value;
    string F_DAUDZ = element.Element(ns + "F_DAUDZ").Value;
    string DAUDZ = element.Element(ns + "DAUDZ").Value;
}

我需要的是从XML节点NKODSF_DAUDZDAUDZ中读取值。

问题是存在具有这些名称的重复节点,并且使用此代码,它为我提供了UzdMat节点下的最后一个节点。在UzdProd下获取这些节点的值的方法是什么? 我尝试将row更改为UzdProd,但这不起作用。

2 个答案:

答案 0 :(得分:1)

您需要读取所需的特定行,而不是遍历所有行。例如:

var prodRow = doc.Descendants(ns + "UzdProd").Elements(ns + "row").Single();
var matRow = doc.Descendants(ns + "UzdMat").Elements(ns + "row").Single();

var prodNkods = (string) prodRow.Element(ns + "NKODS");
var matNkods = (string) matRow.Element(ns + "NKODS");

有关正常工作的演示,请参阅this fiddle

答案 1 :(得分:0)

看看是否有效:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
using System.Xml.Linq;

namespace ConsoleApplication25
{
    class Program
    {
        const string FILENAME = @"c:\temp\test.xml";
        static void Main(string[] args)
        {
            XDocument doc = XDocument.Load(FILENAME);

            XElement entity = doc.Descendants().Where(x => x.Name.LocalName == "entity").FirstOrDefault();
            XNamespace ns = entity.GetDefaultNamespace();

            var results = entity.Elements().Select(x => new {
                uzd = x.Name.LocalName,
                dict = x.Descendants(ns + "row").Elements().GroupBy(y => y.Name.LocalName, z => (string)z)
                   .ToDictionary(y => y.Key, z => z.FirstOrDefault())
            }).ToList();

        }
    }
}