gpt4 book ai didi

c# - 如何针对属性优化 Linq to Xml 查询?

转载 作者:行者123 更新时间:2023-12-02 09:44:08 25 4
gpt4 key购买 nike

给定以下 Xml 片段:

<root>
<sheetData>
<row r="1" />
<row r="2" />
<row r="3" />
<row r="4" />
<row r="5" />
<row r="6" />
<row r="7" />
</sheetData>
</root>

可以使用以下代码创建:

XElement testElement = new XElement("root",
new XElement("sheetData",
new XElement("row",
new XAttribute("r", 1)),
new XElement("row",
new XAttribute("r", 2)),
new XElement("row",
new XAttribute("r", 3)),
new XElement("row",
new XAttribute("r", 4)),
new XElement("row",
new XAttribute("r", 5)),
new XElement("row",
new XAttribute("r", 6)),
new XElement("row",
new XAttribute("r", 7))));

这是查找 r 属性为 2 的行的最佳方法吗?这可行,但我重复了其中的Where子句select语句,想知道是否有更好的方法和更高效的方法。

int rowNumber = 2;

XElement rowElement = testElement
.Descendants("sheetData")
.Where<XElement>(item => item.Descendants("row")
.Where<XElement>(i => i.Attribute("r").Value == rowNumber.ToString())
.FirstOrDefault<XElement>() != null)
.Select<XElement, XElement>(item => item.Descendants("row")
.Where<XElement>(i => i.Attribute("r").Value == rowNumber.ToString())
.FirstOrDefault<XElement>())
.FirstOrDefault<XElement>();

一般来说,确定 Linq to Xml 查询是否优化的最佳方法是什么?

最佳答案

最好的方法是:

var row = testElement
.XPathSelectElements("sheetData/row[@r='2']")
.FirstOrDefault();

不重复 Where 调用的纯 LINQ 查询:

var row = testElement
.Descendants("sheetData")
.Descendants("row")
.Where(x => x.Attribute("r").Value == "2")
.FirstOrDefault();

关于c# - 如何针对属性优化 Linq to Xml 查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/663094/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com