Won*_*nko 5 .net c# xml linq linq-to-xml
当元素名称和所有属性名称和值与输入元素匹配时,我需要替换XElement层次结构中的节点的内容.(如果没有匹配项,则可以添加新元素.)
例如,如果我的数据如下所示:
<root>
<thing1 a1="a" a2="b">one</thing1>
<thing2 a1="a" a2="a">two</thing2>
<thing2 a1="a" a3="b">three</thing2>
<thing2 a1="a">four</thing2>
<thing2 a1="a" a2="b">five</thing2>
<root>
Run Code Online (Sandbox Code Playgroud)
我想在使用此输入调用方法时找到最后一个元素:
<thing2 a1="a" a2="b">new value</thing2>
Run Code Online (Sandbox Code Playgroud)
该方法应该没有硬编码元素或属性名称 - 它只是将输入与数据匹配.
这将使任何给定元素与精确标记名称和属性名称/值对匹配:
public static void ReplaceOrAdd(this XElement source, XElement node)
{
var q = from x in source.Elements()
where x.Name == node.Name
&& x.Attributes().All(a =>node.Attributes().Any(b =>a.Name==b.Name && a.Value==b.Value))
select x;
var n = q.LastOrDefault();
if (n == null) source.Add(node);
else n.ReplaceWith(node);
}
var root = XElement.Parse(data);
var newElem =XElement.Parse("<thing2 a1=\"a\" a2=\"b\">new value</thing2>");
root.ReplaceOrAdd(newElem);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
11268 次 |
| 最近记录: |