如何解决VB.NET Group通过多个属性
当前,我有以下代码将基于多个属性(prop1和prop2)的List(Of CLass1)分组为“ items”。
Dim matchedMethods = items.GroupBy(Function(x) New With_
{Key x.prop1,Key x.prop2,Key x.prop3}).ToList()
这对于将已知数量的属性进行分组是可行的,但是如果我希望按“ n个属性”(prop1,然后是prop2,然后是prop3,然后是propN ...)来排序,该怎么办?
解决方法
您可以使用System.Linq.Dynamic库来实现此目的:它允许您以字符串形式传递表达式(因此可以动态构建字符串)。
我相信您在SDL中的代码将是:
Dim keySelector = "new(it.prop1,it.prop2,it.prop3)"
items.GroupBy(keySelector,"it").ToList()
(但是我目前无法对其进行测试)
要改变它,以不同的方式构建字符串:
Dim keySelector = "new("
If GroupByProp1CheckBox.Checked Then keySelector &= "it.prop1,"
If GroupByProp2CheckBox.Checked Then keySelector &= "it.prop2,"
...
keySelector = keySelector.TrimEnd(","c) & ")"
“ it”是Dynamic.Linq中的预定义内容;等价于x
中的Function(x)
,即列表项
您需要通过nuget添加System.Dynamic.Linq.Core。根据我的经验,还有一个较旧的System.Dynamic.Linq库,可以更轻松地处理某些项目类型(例如.net framework Windows窗体)
,所以我最终这样做了,基本上使用if语句根据propN的数量选择属性->如果有一个,则返回prop,否则就什么也不返回。
像我想要的那样工作(@Calius Jard),如果我有空的话,将不得不在某个时候回到动态库(感谢顺便说一句)。 我对方法不满意的唯一一点是,密钥被导出为{v0 = prop1,v1 = prop2,vN = propN},而不是列表或字典。因此,我最终使用了一些字符串操作来读取这些键。
matchedRecords = items.GroupBy(Function(x) New With {Key .v0 = CallByName(x,prop(0).ToString,CallType.Get),Key .v1 = If(prop.Count >= 2,CallByName(x,prop(1).ToString,Nothing),Key .v2 = If(prop.Count >= 3,prop(2).ToString,Key .v3 = If(prop.Count >= 4,prop(3).ToString,Key .v4 = If(prop.Count >= 5,prop(4).ToString,Key .v5 = If(prop.Count >= 6,prop(5).ToString,Nothing)}).ToList
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。