在 .NET 中从 XML 文档中过滤元素的最简单方法
假设我有以下文档
<sets version="2.0">
<setting>
<id>set1</id>
<value>80</value>
<label>EVersion</label>
<type>Val</type>
<format>R</format>
<bits>
<addr>0</addr>
<startBit>0</startBit>
<bitWidth>8</bitWidth>
</bitspec>
</setting>
<setting>
<id>set3</id>
<value>50</value>
<label>GVersion</label>
<type>Bin</type>
<format>R</format>
<bits>
<addr>0</addr>
<startBit>0</startBit>
<bitWidth>8</bitWidth>
</bitspec>
</setting>
</sets>
,我只想要 ID 和值元素 -
<sets version="2.0">
<setting>
<id>set1</id>
<value>80</value>
</setting>
<setting>
<id>set3</id>
<value>50</value>
</setting>
</sets>
如何使用 XDocument 和 LINQ 仅选择这些元素?
Let's say I have the following doc
<sets version="2.0">
<setting>
<id>set1</id>
<value>80</value>
<label>EVersion</label>
<type>Val</type>
<format>R</format>
<bits>
<addr>0</addr>
<startBit>0</startBit>
<bitWidth>8</bitWidth>
</bitspec>
</setting>
<setting>
<id>set3</id>
<value>50</value>
<label>GVersion</label>
<type>Bin</type>
<format>R</format>
<bits>
<addr>0</addr>
<startBit>0</startBit>
<bitWidth>8</bitWidth>
</bitspec>
</setting>
</sets>
and I just want the ID and value elements -
<sets version="2.0">
<setting>
<id>set1</id>
<value>80</value>
</setting>
<setting>
<id>set3</id>
<value>50</value>
</setting>
</sets>
How could I select just these using XDocument and LINQ?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
使用 linq-to-xml,以下代码:
prints:
如果您不需要转换后的 XML,而只需要
id -> 字典value
映射(将value
存储为int
),你可以这样做:Use linq-to-xml, the following code:
prints:
If you don't need transformed XML, but just, say, dictionary of
id -> value
mapping, (storingvalue
asint
), you could do:这将生成一个匿名类型的
IEnumerable
,其属性为Id
和Value
(均为字符串)。您可以创建自己的
Setting
类型,并在投影中使用它,如果需要,还可以将“value”字符串值转换为整数。This would produce an
IEnumerable
of an anonymous type, with propertiesId
andValue
(both strings).You could create your own
Setting
type, and use that in the projection instead, also converting the 'value' string value to an integer if required.我的第一个答案与其他答案非常相似,并且不太清楚,所以我将其删除。然而,我认为编写一些 linq 是一个很好的练习,当所需元素处于任意深度时,它会生成过滤后的 XML。这就是我想出的:
My first answer was very similar to the other answers, and wasn't as clear, so I removed it. However, I thought it would be a good exercise to write some linq that would generate the filtered XML when the desired elements were at any arbitrary depth. This is what I came up with: