链接到XML子查询
本文关键字:查询 XML 链接 | 更新日期: 2023-09-27 18:02:13
我有以下XML:
<Event ID="1"..... >
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
</Event>
<Event ID="2"..... >
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
</Event>
<Event ID="3"..... >
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
<SubEvent update="DATETIME" />
</Event>
我想删除"事件"元素,其中所有更新属性在SubEvent低于提供的DATETIME。
选择所有这些事件并将它们从文档中删除:
DateTime date = DateTime.Now;
XDocument xdoc = XDocument.Load(path_to_xml);
xdoc.Descendants("Event")
.Where(e => e.Elements().All(se => (DateTime)se.Attribute("update") < date))
.Remove();
xdoc.Save(path_to_xml);
适用于以下xml:
<?xml version="1.0" encoding="utf-8" ?>
<Events>
<Event ID="1" >
<SubEvent update="2013-02-05T17:06:23.8962976+03:00" />
<SubEvent update="2013-03-08T17:06:23.8962976+03:00" />
</Event>
<Event ID="2">
<SubEvent update="2013-01-05T17:06:23.8962976+03:00" />
<SubEvent update="2013-01-05T17:06:23.8962976+03:00" />
<SubEvent update="2013-02-05T17:06:23.8962976+03:00" />
</Event>
<Event ID="3">
<SubEvent update="2013-03-05T17:06:23.8962976+03:00" />
<SubEvent update="2013-04-05T17:06:23.8962976+03:00" />
</Event>
</Events>
假设您没有丢失xml的根目录
var xDoc = // your XDocument
var toDel = new List<XElement>();
foreach(var el in xDoc.Root.Elements("Event").Where(e => e.Elements("SubEvent").All(xel => xel.Attribute("update").Value == "DATETIME")))
{
toDel.Add(el);
}
toDel.ForEach(e => e.Remove());
您必须将.All()
内部的条件替换为理想的
试试这个:
var doc = XDocument.Load(@"D:'input.xml");
var x = new List<XElement>();
foreach (var xElement in doc.Root.Elements("Event"))
{
DateTime maxDt = DateTime.MinValue;
foreach (var element in xElement.Elements("SubEvent"))
{
var attributeValue = element.Attributes("update").FirstOrDefault();
if (attributeValue == null) continue;
DateTime dt;
if (!DateTime.TryParse(attributeValue.Value, out dt)) continue;
if (maxDt < dt) maxDt = dt;
}
xElement.RemoveNodes();
xElement.Add(new XElement("SubEvent", new XAttribute("update", maxDt.ToString("yyyy-MM-dd HH:mm:ss"))));
x.Add(new XElement(xElement));
}
new XDocument(new XElement("ev", x)).Save(@"D:'output.xml");