如何从xml中删除null属性?

时间:2013-08-09 15:26:01

标签: c# xml linq

背景:我正在通过XamlReader.Load()从文件加载一个类,使用它然后通过XamlWriter.Save()将其保存回文件。原始文件没有空属性,但生成的已保存文件具有所有属性,无论它们是否为空,并且它会使文件膨胀。所以我想在实际保存到磁盘之前删除它们。

我将以下xml片段作为字符串。我需要删除所有以“{assembly:Null}”为值的属性。

<ElementMap ElementType="SegmentData" 
  Key="{assembly:Null}" 
  EntityPropertyMapping="SenderCode" 
  Name="Application Sender's Code" 
  ElementCode="GS02" 
  EdiDataType="AN" 
  EntityDataType="String" 
  MinLength="2" 
  MaxLength="15" 
  Position="0" 
  ElementIndex="2" 
  ValidateData="False" 
  Parent="{assembly:Null}" 
  IsRequired="True" 
  Note="{assembly:Null}" 
  Default="{assembly:Null}" 
  Example="{assembly:Null}" 
  ExcludeFromStringOutput="False" />

最终结果将是:

<ElementMap 
  ElementType="SegmentData" 
  EntityPropertyMapping="SenderCode" 
  Name="Application Sender's Code" 
  ElementCode="GS02" 
  EdiDataType="AN" 
  EntityDataType="String" 
  MinLength="2" 
  MaxLength="15" 
  Position="0" 
  ElementIndex="2" 
  ValidateData="False" 
  IsRequired="True" 
  ExcludeFromStringOutput="False" />

那怎么能实现呢?

2 个答案:

答案 0 :(得分:3)

您可以使用LINQ to XML:

var elementMap = XElement.Load(path_to_xml); // or XElement.Parse(xml_string)
elementMap.Attributes().Where(a => (string)a == "{assembly:Null}").Remove();
elementMap.Save(path_to_xml);

Extensions.Remove()方法从父节点中删除每个匹配的属性。

答案 1 :(得分:1)

XElement element = //get the XElement
element = new XElement(element.Name,
     element.Attributes.Where(a => (string)a != "{assembly:Null}")
     .Concat(element.Elements()).ToArray());