以前我曾询问过如何在数据集中插入一列.我现在有一个类似的问题......即将两列或多列合并为一列.
假设我有以下数据集:
DataSet ds = new DataSet(); ds.Tables.Add(new DataTable()); ds.Tables[0].Columns.Add("id", typeof(int)); ds.Tables[0].Columns.Add("firstname", typeof(string)); ds.Tables[0].Columns.Add("lastname", typeof(string));
我需要将"firstname"和"lastname"列合并到一个名为"name"的列中.
我最好创建一个将两列合并在一起的方法,还是可以用来将多列合并在一起的更通用的方法?
我的想法是创建一个类似于以下的通用方法:
MergeColumns(字符串格式,字符串mergedColumn,DataTable dt,params string [] columnsToMerge)
用户提供如下格式:"{0} {1}"
mergedColumn是新列的名称...但它必须能够与将要合并的列之一相同,因为在我的真实案例中我将"name"和"given_names"合并为"name" ...但是如果我需要将"街道","城市","州","邮政编码"等合并到名为"地址"的列中,我仍然希望能够使用它.
我认为这将使用的方式如下:
MergeColumns("{0} {1}","name",dataTable,"firstname","lastname");
鉴于上述数据集,我希望结果数据集看起来如下:
DataSet ds = new DataSet(); ds.Tables.Add(new DataTable()); ds.Tables[0].Columns.Add("id", typeof(int)); ds.Tables[0].Columns.Add("name", typeof(string));
这看起来像是一种合理的方法吗?这样的方法是否已经存在?我不想重新发明轮子.另外,我是否正在创建一种比我现在实际需要的更多的方法?
public partial class Form1 : Form { public Form1() { InitializeComponent(); DataSet ds = new DataSet(); ds.Tables.Add(new DataTable()); ds.Tables[0].Columns.Add("id", typeof(int)); ds.Tables[0].Columns.Add("firstname", typeof(string)); ds.Tables[0].Columns.Add("lastname", typeof(string)); ds.Tables[0].Rows.Add(1,"torvalds", "linus"); ds.Tables[0].Rows.Add(2,"lennon", "john"); ds.Tables[0].MergeColumns("name", "lastname", "firstname"); foreach (DataRow dr in ds.Tables[0].Rows) MessageBox.Show(dr["name"].ToString()); } } public static class Helper { public static void MergeColumns(this DataTable t, string newColumn, params string[] columnsToMerge) { t.Columns.Add(newColumn, typeof(string)); var sb = new StringBuilder(); sb.Append("{0}, "); for (int i = 1; i < columnsToMerge.Length; ++i) sb.Append("{" + i.ToString() + "}"); string format = sb.ToString(); foreach(DataRow r in t.Rows) r[newColumn] = string.Format(format, columnsToMerge.Select(col => r[col]).ToArray() ); } }