用Linq从xml列表中删除项目



我有以下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();

相关内容

  • 没有找到相关文章

最新更新