我正在编写一些代码,我想使用C#的匿名功能来完成它。
我正在根据从SQL Server返回的DataTable编写摘要。
有很多方法我可以写它已经知道 Classical 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
(上面)不起作用!
是什么?
答案 0 :(得分:6)
您需要使用类型推断:
new[] { part }.ToList()
(您可能希望之后清除列表)
你也可以制作一个辅助方法:
public static List<T> ListOf<T>(T sample) {
return new List<T>();
}
var parts = ListOf(part);