Linq To XML从xml文件中删除文档

时间:2016-07-12 18:21:52

标签: c# xml linq

我有一个xml文件。这是一个简短的部分:

<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<documents>
    <document>
        <head>
            <date>01/01/2015</date>
            <nr>1001</nr>
        </head>
        <body>
            <name>Mark Sweden</name>
            <cf>AAABBBCCC</cf>
        </body>
    </document>
    <document>
        <head>
            <date>01/01/2015</date>
            <nr>1002</nr>
        </head>
        <body>
            <name>John Car</name>
            <cf>AAABBBVVV</cf>
        </body>
    </document>
    <document>
        <head>
            <date>01/01/2015</date>
            <nr>1004</nr>
        </head>
        <body>
            <name>Mark Sweden</name>
            <cf>AAABBBCCC</cf>
        </body>
    </document>
</documents>

我想使用Linq to XML删除每个具有特定“cf”值的文档。 例如,如果“cf”值是AAABBBCCC,则第一个文档将被删除。

谢谢。

更新

我的问题是要删除文件(我写的linq查询错了)。罗伯特麦基向我指出了正确的方向。 我的解决方案是:

var Delete = (from x in doc.Descendants(document)
where x.Descendants("cf").First().Value = "AAABBBCCC"
select x);

Delete.Remove();

3 个答案:

答案 0 :(得分:1)

试试这段代码:它应该几乎是自动解释,但让我知道任何疑问

var root = XElement.Load(myPath);
List<XElement> deleteMe = new List<XElement>();
foreach (var item in root.Elements())
{
    if (item.Element("body").Element("cf").Value.Equals(myCf))
    {
        deleteMe.Add(item);
    }
}
Console.WriteLine("Deleting: " + String.Join(",",deleteMe.Select(x => x.Element("head").Element("nr").Value)));
Console.ReadKey();
foreach (var item in deleteMe)
{
    item.Remove();
}
root.Save(myPath2);

答案 1 :(得分:0)

使用XDocument,您可以生成没有不需要的元素的文档副本,然后覆盖原始文件:

string documentPath;
string undesiredPattern = "AAABBBCCC";
XDocument xdoc = XDocument.Load(documentPath);
//Or, if your document is already loaded on a string, use XDocument.Parse(string)
XElement root = xdoc.Root;

IEnumerable<XElement> desiredElements = 
 root.
 Elements().
 Where(x=>!x.Element("body").Element("cf").Value.Equals(undesiredPattern));

XDocument newDoc = new XDocument(new XDeclaration("1.0", "utf-8", "yes"));
XElement newRoot = new XElement("documents");
foreach(XElement xe in desiredElements)
{
  newRoot.Add(xe);
}
newDoc.Add(newRoot);
newDoc.Save(documentPath);

编辑: 其他方式,更直接(如果你想从文件加载,而不是XDocument.Parse使用XDocument.Load和XDocument.Save保存之后,如上面所示):

string document = "your xml";
string undesiredPattern = "AAABBBCCC";
XDocument xdoc = XDocument.Parse(document);

xdoc.Root.Elements().Where(x=>
  x.Element("body").
  Element("cf").Value.
  Equals(undesiredPattern)).Remove();

答案 2 :(得分:0)

var xml=@"<?xml version=""1.0"" encoding=""utf-8"" standalone=""yes""?>
<documents>
    <document>
        <head>
            <date>01/01/2015</date>
            <nr>1001</nr>
        </head>
        <body>
            <name>Mark Sweden</name>
            <cf>AAABBBCCC</cf>
        </body>
    </document>
    <document>
        <head>
            <date>01/01/2015</date>
            <nr>1002</nr>
        </head>
        <body>
            <name>John Car</name>
            <cf>AAABBBVVV</cf>
        </body>
    </document>
    <document>
        <head>
            <date>01/01/2015</date>
            <nr>1004</nr>
        </head>
        <body>
            <name>Mark Sweden</name>
            <cf>AAABBBCCC</cf>
        </body>
    </document>
</documents>";
var doc = XDocument.Parse(xml);
foreach(var node in var node in doc.Descendants("document").Where(d=>d.Descendants("cf").First().Value=="AAABBBCCC").ToArray())
{
    node.Remove();
}