我有以下xml文件:
<ArrayOfNO xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<No>
<Id>0</Id>
<Name>txt_0</Name>
<Texto>Função 0</Texto>
<Txt_relacionados>
<string>txt_1</string>
<string>txt_2</string>
</Txt_relacionados>
<Nível>2</Nível>
<X>393</X>
<Y>55</Y>
</No>
<No>
<Id>0</Id>
<Name>txt_1</Name>
<Texto>Função 0</Texto>
<Txt_relacionados>
<string>txt_0</string>
</Txt_relacionados>
<Nível>1</Nível>
<X>234</X>
<Y>115</Y>
</No>
<No>
<Id>1</Id>
<Name>txt_2</Name>
<Texto>Função 1</Texto>
<Txt_relacionados>
<string>txt_0</string>
</Txt_relacionados>
<Nível>1</Nível>
<X>234</X>
<Y>115</Y>
</No>
</ArrayOfNO>
我希望当元素被删除时(例如,"txt2"
),程序在所有元素的<Txt_relacionados>
中查找,检查是否有与"txt_2"
相关的项,如果是,则删除。
我已经删除了下面代码的项目(它正在工作):
public void remove(String name)
{
RefreshXDoc();
var oEmp = doc.Descendants().Elements("No")
.Where(d => d.Element("Name").Value == name)
.FirstOrDefault();
if (oEmp == null)
{
return;
}
oEmp.Remove();
SaveXDoc();
}
但首先需要从列表"txt_relacionados"中删除所有与之相关的元素(不知道如何实现)。我尝试这样做:
var oEmp = doc.Descendants("No").Elements("Txt_relacionados")
.Where(d => d.Element("string").Value == name)
.ToList();
oEmp.Remove();
SaveXDoc();
有人有建议吗?谢谢!
您可以尝试通过这种方式删除<Txt_relacionados>
中所有值等于name
的<string>
元素:
doc.Descendants("No")
.Elements("Txt_relacionados")
.Elements("string")
.Where(s => (string)s == name)
.Remove();
SaveXDoc();
这里不需要ToList()
,您可以直接调用扩展方法.Remove()
,因为该方法是为IEnumerable<XNode>
源定义的。
首先从xml结构中删除节点,然后保存新的xml结构:
foreach (var node in oEmp)
{
node.ParentNode.RemoveChild(oEmp);
}
SaveXDoc();