在C#中,可以使用DataTable的Columns集合来动态增加列。除了直接添加列之外,还可以通过计算、转换等方式对列进行高级操作。
以下是一些添加列的高级应用示例:
- 使用表达式添加计算列:
DataTable dt = new DataTable(); dt.Columns.Add("Number1", typeof(int)); dt.Columns.Add("Number2", typeof(int)); dt.Columns.Add("Sum", typeof(int), "Number1 + Number2");
- 使用自定义方法添加列:
DataTable dt = new DataTable();
dt.Columns.Add("Name", typeof(string));
dt.Columns.Add("Age", typeof(int));
dt.Columns.Add("Category", typeof(string));
foreach (DataRow row in dt.Rows)
{
row["Category"] = GetCategory(row["Age"]);
}
private string GetCategory(int age)
{
if (age < 18)
return "Child";
else
return "Adult";
}
- 使用Lambda表达式添加列:
DataTable dt = new DataTable(); dt.Columns.Add("Name", typeof(string)); dt.Columns.Add("Age", typeof(int)); dt.Columns.Add("IsAdult", typeof(bool)).Expression = "IIF(Age >= 18, true, false)";
这些示例展示了如何在DataTable中使用高级方法来动态添加列,可以根据具体需求选择适合的方法。