NB:在这里,字典是"
我有一个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多行代码,因此我需要一种更有效的方法,而不仅仅是一个值和一个元素,然后将其添加到列表中...
使用linqtoxml加载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"]
一样的Acessing值。
livedemo
NB:在这里,字典是"
[String,String]
",但您可以转换值以满足您的需求。您可以尝试此代码。
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; }
}