如何从XDocument更改为XMLDocument代码?

时间:2018-04-16 14:01:37

标签: c# winforms xmldocument

嘿,我有两个xml文件和以下代码:

        DataTable table = new DataTable();

        List<string> headingNames = new List<string>();
        List<string> valueNames = new List<string>();

        //first xml file
        XDocument config = XDocument.Load(configFile);

        Dictionary<string, string> dict = config.Descendants("Columns").FirstOrDefault().Elements()
            .GroupBy(x => (string)x.Attribute("XPath"), y => (string)y.Attribute("Name"))
            .ToDictionary(x => x.Key, y => y.FirstOrDefault());

        //second xml file
        XDocument data = XDocument.Load(dataFile);

        List<XElement> positions = data.Descendants("Position").ToList();

但我必须将其更改为XMLDocument代码。

这是第一个XML:

<?xml version="1.0" encoding="utf-8"?>
<ROOT>
 <Columns BaseXPath="//Orders/Position/">
  <Colum XPath="@PositionSK" Name="Position"/>
  <Colum XPath="@PosGroup" Name="Gruppen-Nr"/>
  <Colum XPath="@PosNumber" Name="PositionsNr"/>
  <Colum XPath="@PositionCommercialTypeSK" Name="Status"/>
  <Colum XPath="@BundlePositionSK" Name="BundlePositionSK"/>
  <Colum XPath="@MainPositionSK" Name="MainPositionSK"/>
  <Colum XPath="@SalesAgentPrice" Name="Preis"/>
  <Colum XPath="@Catchword" Name="Suchwort"/> 
  <Colum XPath="@ContentComponentCommSK" Name="IKO"/>
  <Colum XPath="@PositionTypeSK" Name="PositionsTyp"/>
  <Colum XPath="//Advertisement[@AdvertisementSK = PositionAdvertisementRelationship/@AdvertisementSK]/@AdvertisementSK" Name="AdvertisementSK"/>
  <Colum XPath="//Advertisement[@AdvertisementSK = PositionAdvertisementRelationship/@AdvertisementSK]/@AdvertisementTypeSK" Name="Formatvorgabe"/>
 </Columns>
</ROOT>

我希望所有的名字都带有@和&#34;名称&#34;:位置,Gruppen-Nr,......

所以在Dic(来自我的代码)中站着 {[@ PositionSK,Position]},{[@PosGroup,Gruppen-Nr]},...

那么如何使用XMLDocument获得相同的结果呢?

下一步我有:

        foreach (XElement position in positions.Where(e => e.HasAttributes))
        {
            valueNames.Clear();
            headingNames.Clear();

            foreach (XAttribute attribute in position.Attributes().Where(a => dict.ContainsKey($"@{a.Name.LocalName}")))
            {
                string name = attribute.Name.LocalName;
                string xName = dict["@" + name];
                string value = (string)attribute;

                headingNames.Add(xName);

                valueNames.Add(value);
            }

输出将是DataGridView上的DataTable。 它应该在另一个xml文件中使用@搜索Names并找到它们的值。但需要使用XMLDocument的代码..而不是使用linq ..任何人都可以帮助我吗?

1 个答案:

答案 0 :(得分:1)

这方面的一个基本例子是:

List<string> valueNames = new List<string>();
List<string> headingNames = new List<string>();

XmlDocument doc = new XmlDocument();
doc.Load("data.xml");

for (int r = 0; r < doc.ChildNodes.Count; r++)
{
    var currentNode = doc.ChildNodes.Item(r);
    if (currentNode.Name.Equals("ROOT"))
    {
        var columnsNode = currentNode.FirstChild;

        for (int i = 0; i < columnsNode.ChildNodes.Count; i++)
        {
            XmlNode child = columnsNode.ChildNodes.Item(i);

            for (int j = 0; j < child.Attributes.Count; j++)
            {
                var attribute = child.Attributes.Item(j);
                if (attribute.Name.Equals("XPath"))
                {
                    headingNames.Add(attribute.Value);
                }
                else if (attribute.Name.Equals("Name"))
                {
                    valueNames.Add(attribute.Value);
                }
            }
        }
    }
}

一些解释:

  • 您的示例XML没有XML声明,因此我们可以让Root Element只是访问FirstChild属性。

  • 编辑之后:您的示例XML现在有一个XML声明,但模式是相同的。 For循环并访问此循环的每个索引器的子元素。

  • &#39;列&#39;元素可以达到相同的方式。

  • 在&#39;列上&#39;元素我们循环遍历所有子节点并使用循环的索引器(i)来获取相应的元素。为什么?因为它是XmlNodeList对象。

  • 使用我们的XmlNode child我们也会这样做,但这次没有使用子节点。相反,我们遍历属性节点并寻找正确的名称。