1

我有一个这种格式的 csv 文件

 A,B,value
 a1,b1,10
 a2,b1,12
 a2,b1,15
 a2,b2,14
 a1,b1,12

我在我的应用程序中将其转换为数据表。

 Dim enumerable = _dt.AsEnumerable

 Dim groupedResults = enumerable.GroupBy( _
                                   Function(x) _
                                        New With { _
                                                  .A = x.Item("A").ToString, _
                                                  .B = x.Item("B").ToString _
                                                 } _
                                        )

我希望 groupedResults 计数为 4 而不是显示的 5。
基本上它不会按第 1 行和第 5 行归为一组。

我预计具有相同值的对象将产生相同的键。

可能是什么原因?

4

1 回答 1

5

使匿名类型属性不可变——这是使相等和散列起作用的方法。(在 C# 中,默认情况下所有匿名类型都是不可变的。)

试试这个

 Dim enumerable = _dt.AsEnumerable

 Dim groupedResults = enumerable.GroupBy( _
               Function(x) _
                    New With { _
                              Key .A = x.Item("A").ToString, _
                              Key .B = x.Item("B").ToString _
                             } _
                    )

编辑:这Key部分意味着属性是匿名类型的键。有关详细信息,请参阅VB 匿名类型 MSDN 页面

于 2009-03-09T16:20:32.740 回答