我有一个像这样的xml文件
<Document>
<Tests>
<Test>
<Name>A</Name>
<Type>Like A</Type>
<Members>
<Member>1</Member>
<Member>2</Member>
<Member>3</Member>
</Members>
</Test>
<Test>
<Name>B</Name>
<Type>Like B</Type>
<Members>
<Member>4</Member>
<Member>5</Member>
<Member>6</Member>
</Members>
</Test>
</Tests>
</Document>
现在我创建了一个类来保存每个Test节点的数据:
public class TestData
{
public string Name {get;set;}
public string Type {get;set;}
public List<string> Members = new List<string>();
public AddMembers(List<string> members)
{
Members.AddRange(members);
}
}
现在我正在尝试使用xpath来填充我的TestData类,但是我有问题将成员添加到我拥有的List中。我正在尝试使用LINQ,但我还是不能这样做:(
public List<TestClass> GetTests()
{
List<TestClass> tests = new List<TestClass>();
TestClass test;
XPathNodeIterator it = nav.Select("/Document/Tests/Test");
foreach (XPathNavigator val in it)
{
test= new TestClass();
test.Name = val.SelectSingleNode(nav.Compile("Name")).Value;
test.Type = val.SelectSingleNode(nav.Compile("Type")).Value;
test.AddMembers(); //How can I return all the member nodes in a list?
tests.Add(test);
}
return tests ;
}
答案 0 :(得分:3)
说实话,目前还不清楚为什么要使用XPathNodeIterator。如果您可以使用LINQ to XML,那很简单:
var list = doc.Descendants("Test")
.Select(x => TestClass.FromXElement(x))
.ToList();
TestClass.FromXElement
类似于:
public static TestClass FromXElement(XElement element)
{
string name = (string) element.Element("Name");
string type = (string) element.Element("Type");
List<string> members = element.Descendants("Member")
.Select(x => x.Value)
.ToList();
return new TestClass(name, type, members);
}
(如果您更严格地控制层次结构,则不必使用Descendants
。例如,在TestClass.FromXElement
中您可以使用element.Element("Members").Elements("Member")
答案 1 :(得分:1)
试试这个:
IEnumerable<string> members =
from m in ((IEnumerable<XmlNode>)((IHasXmlNode)val).GetNode()
.SelectNodes("Members/Member"))
select m.Value;