0

我有一个包含 100 个字段元素的父 xslt(存在嵌套字段)。现在我需要创建一个包含 50 个字段(基于 excel 文件)的子 xslt,保留与父级相同的结构,从父级中删除一些不需要的字段。关于我如何进行的任何输入。

4

1 回答 1

0

假设您已经知道如何使用要删除的字段列表填充数组(或其他集合),您应该能够执行以下操作:

string[] fields = new string[] { "c", "d" };
// In actuality, the assumption is that your XmlDocument is loaded some other way
XmlDocument document = new XmlDocument();
document.LoadXml("<ABCD> <a>1</a> <b>2</b> <c>3</c> <d>4</d> </ABCD>");

string xpath = "//*[" + fields.Select(v => "self::" + v)
                              .Aggregate((a, b) => a + " or " + b) 
                      + "]";
List<XPathNavigator> nodes = document.CreateNavigator().Select(xpath).Cast<XPathNavigator>().ToList();
foreach (XPathNavigator node in nodes)
{
    node.DeleteSelf();
}

string resultDoc = document.OuterXml;
于 2013-01-30T08:34:42.133 回答