1

我正在编写一些代码,我想尝试使用 C# 的匿名功能来完成它。

我正在根据从 SQL Server 返回的 DataTable 编写摘要。

我已经知道古典 C# (???),有很多方法可以编写它,但我有兴趣找点乐子。

所以,这是我想要的匿名类的类型:

// Employee
var emp = new {
  Badge = "000000",
  Name = "No Name",
  Parts = new List<Part>(),
  Days = new List<DateTime>(),
};

// Part
var part = new {
  SerialNumber = "N/A",
  Date = DateTime.MinValue,
  Badge = "000000",
};

现在,当我遍历我的 DataTable 条目时,我想按SerialNumber.

我要做的第一件事是将数据分解为几天。

private void TestMethod(DateTime minDate, DateTime maxDate, DataTable table) {
  int days = 1;
  var nextDay = minDate.AddHours(24);
  foreach (DataRow row in table.Rows) {
    var dateTime = (DateTime)row["Date_Time"];
    var emp = new {
      Badge = row["Badge"].ToString(),
      Parts = new List<Part>(),
      Days = new List<DateTime>(),
    };
    var part = new {
      SerialNumber = row["Serial_Number"].ToString(),
      Date = dateTime,
      Badge = row["Badge"].ToString(),
    };
    if (nextDay < dateTime) {
      days++;
      nextDay = nextDay.AddHours(24);
    }
  }

现在,它变得有点有趣了。

我需要一种方法来存储不同日期的零件信息以及该期间找到的不同员工。

我将如何创建和使用我的匿名类项目的匿名集合?

var parts = new List<typeof(part)>();
var emps = new List<typeof(emp)>();

使用typeof(上面)不起作用!

有什么作用?

4

1 回答 1

6

您需要使用类型推断:

new[] { part }.ToList()

(你可能想在之后清除列表)

您还可以创建一个辅助方法:

public static List<T> ListOf<T>(T sample) {
    return new List<T>();
}
var parts = ListOf(part);
于 2013-08-05T20:07:56.927 回答