0

我已经有了指定列的代码,dataTable但我想要的是创建一个包含在她的参数中的通用方法:ColumnName和类型。我怎样才能做到这一点?

这是我的代码:

column = dt.Columns.Add();
column.ColumnName = "IPPName";
column.DataType = typeof(String);

column = dt.Columns.Add();
column.ColumnName = "tagName";
column.DataType = typeof(String);

column = dt.Columns.Add();
column.ColumnName = "time";
column.DataType = typeof(String);

column = dt.Columns.Add();
column.ColumnName = "value";
column.DataType = typeof(Double);

column = dt.Columns.Add();
column.ColumnName = "qtity";
column.DataType = typeof(Double);
4

2 回答 2

2

我不知道我是否正确理解了问题。你想实现这样的东西吗?

      public DataTable  CreateDataTable(Dictionary<string,Type> columns)
      {
            DataTable dt = new DataTable();
            foreach( var key in columns)
            {
                var column = dt.Columns.Add();
                column.ColumnName = key.Key;
                column.DataType = key.Value;
            }
            return dt;

        }


        public void CreateNewDataTable()
        {
            var columns = new Dictionary<string, Type>()
                {
                    {"column", typeof (string)}
                };
            var dt = CreateDataTable(columns);
        }
于 2013-01-16T07:57:29.087 回答
0

使用扩展方法解决它的另一种方法。我相信它比@adt 答案更容易理解并且更有用,因为它可以在已经存在的DataTable.

如果您需要有关扩展方法的帮助,请查看此说明或询问 :)

public static class DataTableExtentions {
  public static void AddColumn(this DataTable table, string columnName, Type columnType)
  {
    var col = table.Columns.Add();
    col.ColumnName = columnName;
    col.DataType = columnType;
  }
}

它会被这样调用:

column = dt.AddColumn("IPPName", typeof(String));

column = dt.AddColumn("tagName", typeof(String));

column = dt.AddColumn("time", typeof(String));

column = dt.AddColumn("value", typeof(Double));

column = dt.AddColumn("qtity", typeof(Double));
于 2013-01-16T08:40:51.810 回答