gpt4 book ai didi

c# - Linq 语句 : Order by

转载 作者:太空宇宙 更新时间:2023-11-03 17:39:16 25 4
gpt4 key购买 nike

我有一个从 Web API 请求返回的对象列表。每个对象都有一个名为“PlaceNo”的字段,它的值可以是 0 到 n ,如果没有分配值,则为 -1。

我需要根据 PlaceNo 对列表进行排序,其中它需要为 0 到 n ,然后是所有 -1。

allreports.OrderBy(x => Convert.ToInt32(x.PlaceNo)).ToList();

目前的代码首先给出所有的-1,然后是0到n。

注意:我在 PlaceNo 上进行类型转换,因为数字是作为字符串而不是整数传递的。

最佳答案

解决这个问题的正确方法是进行先排序查询。虽然其他答案的建议——将负数转换为最大整数——会可能工作,最佳实践是编写代码,使其实际代表您试图在代码中捕获的操作。在这种情况下,您有两个 排序标准,因此您应该在查询中有两个 排序标准!

您要做的是首先对“是整数 -1 吗?”进行排序。也就是说,按 bool 数量订购。默认顺序是 false 在 true 之前,所以如果您希望 -1 排在最后,请检查整数是否等于 -1。

那应该是您的 order-by 子句。 then-by 子句就是您的正常排序——按整数值。

var query = from report in allreports
let place = Convert.ToInt32(report.PlaceNo)
  orderby place == -1, place
select report;
var list = query.ToList();

有道理吗?

关于c# - Linq 语句 : Order by,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37175399/

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