XDocument将所有元素名称和值返回到两个单独的列表

时间:2019-07-02 09:08:36

标签: c# xml list linq-to-xml

我有一个如下所示的XML文档:

<Settings>
  <!-- Comment1 -->
  <A> 1 </A>
  <!-- Comment2 -->
  <B> 2 </B>
  <!-- Comment3 -->
  <C> 3 </C>
  <!-- Comment4 -->
  <D> 4 </D>
</Settings>

如何将元素名称(A,B,C,D)添加到列表中,以及如何将元素值(1,2,3,4)添加到另一个列表中。请注意,实际上我正在处理的XML文件具有超过1000多行代码,因此,我需要一种比仅将每个值和元素一一提取并添加到列表中更有效的方法...

2 个答案:

答案 0 :(得分:2)

使用LinqToXML将Xml的一部分解析为Dictionary,加载Xdocument。
在设置下选择所有内容。 枚举这些元素并将其制成字典。

如果元素重复,请将ToDictionary替换为Select

string input = @"<root>
<Settings>
    <A> 1 </A>
    <B> 2 </B>
    <C> 3 </C>
    <D> 4 </D>
</Settings>
<Hello>World</Hello>
<Foo>Bar</Foo>
</root>";

XDocument xdoc = XDocument.Parse(input);

var result = xdoc.Descendants("Settings")
    .Elements()
    .ToDictionary(
        el => el.Name.LocalName,
        el => el.Value 
    );

结果:

Dumping object(System.Collections.Generic.Dictionary`2[String,String])
  [
   [A,  1 ]
   ,
   [B,  2 ]
   ,
   [C,  3 ]
   ,
   [D,  4 ]
]

诸如settings["A"]之类的值。

LiveDemo


注意:这里的词典是“ [String,String]”,但是您可以根据需要转换值。

答案 1 :(得分:0)

您可以尝试使用此代码。

class Program
    {
        static void Main(string[] args)
        {
            //Declare and load your xml file
            XmlDocument xmlDoc = new XmlDocument();
            xmlDoc.Load("XMLFile.xml");

            //Instatiate the object where you want to store the list values
            XMLData xmlData = new XMLData();
            xmlData.listKeys = new List<string>();
            xmlData.listValues = new List<string>();

            //Pick the settings parent node 
            XmlNode xmlSettingsNode = xmlDoc.FirstChild;

            //Loop through the list and add name and values to list
            foreach (XmlNode xmlNode in xmlSettingsNode.ChildNodes)
            {
                //Ignore commented lines
                if (xmlNode.NodeType != XmlNodeType.Comment)
                {
                    xmlData.listKeys.Add(xmlNode.Name);
                    xmlData.listValues.Add(xmlNode.InnerText);
                }
            }
        }
    }

//Data model for storing list data
    public class XMLData
    {
       public List<string> listKeys { get; set; }
       public List<string> listValues { get; set; }

    }