我有一个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();
答案 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();
}