我有一个如下所示的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多行代码,因此,我需要一种比仅将每个值和元素一一提取并添加到列表中更有效的方法...
答案 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"]
之类的值。
[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; }
}