我是LINQ/XML的新手。我刚刚了解到语言集成查询可以用于解析xml。我正在尝试解析以下XML结构,我需要帮助
==================================
<config>
<params>
<tp name="abc">yes</tp>
<tp name="aee">no</tp>
<tp name="bbc">no</tp>
<tp name="ccb">yes</tp>
</params>
<nits>
<tn name="kjh">
<min>44</min>
<max>98</max>
</tn>
<tn name="klm">
<min>55</min>
<max>88</max>
</tn>
<tn name="hhh">
<min>44</min>
<max>98</max>
</tn>
</nits>
<params>
<tp name="lml">no</tp>
<tp name="rre">yes</tp>
<tp name="rst">no</tp>
<tp name="wee">yes</tp>
</params>
<nits>
<tn name="adf">
<min>44</min>
<max>98</max>
</tn>
<tn name="ddd">
<min>42</min>
<max>92</max>
</tn>
<tn name="kjj">
<min>92</min>
<max>98</max>
</tn>
</nits>
</config>==================================
需要的输出:
我的目标是在文本文件或数据网格等文件中按类别将上述数据显示为键值对。
<Params>
abc : yes
aee : no
bbc : yes
...
...
...
...
<nits>
kjh: 44 , 98
klm: 55 , 88
...
...
kjj: 92 , 98
ddd: 42 , 92
...到目前为止,我写的代码是,
static void QueryTheData(XDocument doc)
{
try
{
var a = doc.Descendants("config").Elements("params");
var b = doc.Descendants("config").Elements("nits");
var c = doc.Elements("tp");
var d = doc.Elements("tn");
/* to do : parse the elements into key value pairs */
/* Need hint or help to proceed to get key value pairs from xml data
}
catch(Exception e)
{
....
}
}XML/ ANy C#初学者的好指针也是需要的。
提前感谢,ak
发布于 2012-09-22 06:34:33
我想出了这个:
using System.Linq;
using System.Xml.Linq;
using System.Xml.XPath;
using System.IO;
using System;
public class Program
{
public static void Main(string[] args)
{
using (var fs = new StreamReader("./test.xml"))
{
var doc = XDocument.Load(fs);
var parms = doc.Root.XPathSelectElements("params/tp")
.ToDictionary(el => el.Attribute("name").Value, el => el.Value);
var nits = doc.Root.XPathSelectElements("nits/tn")
.Select(el => new {
Name = el.Attribute("name").Value,
Min = (int) el.Element("min"),
Max = (int) el.Element("max")
}).ToList();
foreach (var kvp in parms)
Console.WriteLine("{0}: {1}", kvp.Key, kvp.Value);
foreach (var nit in nits
.OrderBy(nit => nit.Name)
.ThenBy(nit => nit.Max))
{
Console.WriteLine("{0}: {1} {2}", nit.Name, nit.Min, nit.Max);
}
}
}
}这向您展示了一些成分,包括在集合类型中存储params/nit的不同方法。输出:
abc: yes
aee: no
bbc: no
ccb: yes
lml: no
rre: yes
rst: no
wee: yes
adf: 44 98
ddd: 42 92
hhh: 44 98
kjh: 44 98
kjj: 92 98
klm: 55 88发布于 2012-09-22 06:14:34
"ANy初学者的LINQ/XML C#的好指针也是必要的。“
你可能会发现.NET Language-Integrated Query for XML Data很有帮助,它谈到了如何使用LINQ to XML。
发布于 2012-09-22 06:18:05
那么,您想从每个<tp>元素中获取name属性和文本值吗?这很简单:
// Parameters
var query = doc.Descendants("tp")
.Select(tp => new { Name = tp.Attribute("name").Value,
Value = tp.Value });
foreach (var result in query)
{
Console.WriteLine("{0} : {1}", result.Name, result.Value);
}对于最小/最大部分也是如此:
var query = doc.Descendants("tn")
.Select(tn => new { Name = tn.Attribute("name").Value,
Min = (int) tn.Element("min"),
Max = (int) tn.Element("max") });
foreach (var result in query)
{
Console.WriteLine("{0}: {1}, {2}", result.Name, result.Min, result.Max);
}当然,这假设XML遵循您所布置的模式--如果元素没有正确的子元素或属性,它将失败。
https://stackoverflow.com/questions/12538770
复制相似问题