我有一个XML文件,如下所示
<Attachment>
<FileName>Perimeter SRS.docx</FileName>
<FileSize>15572</FileSize>
<ActivityName>ActivityNamePerimeter SRS.docx</ActivityName>
<UserAlias>JameelM</UserAlias>
<DocumentTransferId>7123eb83-d768-4a58-be46-0dfaf1297b97</DocumentTransferId>
<EngagementName>EAuditEngagementNameNew</EngagementName>
<Sender>JameelM@orioninc.com</Sender>
</Attachment>
我读了这些xml文件,如下所示
var doc = new XmlDocument();
doc.Load(files);
foreach (XmlElement pointCoord in doc.SelectNodes("/Attachment"))
{
}
我需要在Attachment节点中获取每个子节点值。如何从xml节点列表中获取这些xml元素?
答案 0 :(得分:7)
我需要在Attachment节点中获取每个子节点值。
您的问题非常不清楚,但看起来就像它一样简单:
foreach (XmlNode node in doc.DocumentElement.ChildNodes)
{
}
毕竟,在您向我们展示的文档中,Attachment
是文档元素。不需要XPath。
另外,如果您使用的是.NET 3.5或更高版本,LINQ to XML是一个 更好的XML API,而不是旧的DOM(XmlDocument
等)API。
答案 1 :(得分:1)
试试这个
var data = from item in doc.Descendants("Attachment")
select new
{
FileName= item.Element("FileName").Value,
FileSize= item.Element("FileSize").Value,
Sender= item.Element("Sender").Value
};
foreach (var p in data)
Console.WriteLine(p.ToString());
答案 2 :(得分:0)
var doc = new XmlDocument();
doc.Load(files);
foreach (XmlElement pointCoord in doc.SelectNodes("/Attachment"))
{
if(pointCoord!=null)
{
var valueOfElement=pointCoord.InnerText;
}
}
如果要对元素名称(UserAlias等)运行条件逻辑,则使用XmlElement的Name属性。