gpt4 book ai didi

c# - 如何合并数据集中的两列?

转载 作者:行者123 更新时间:2023-11-30 19:52:06 25 4
gpt4 key购买 nike

之前我问过关于 inserting a column into a dataset 的问题.我现在有一个类似的问题...即将两列或多列合并为一列。

假设我有以下数据集:

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(string format, string mergedColumn, DataTable dt, params string[] columnsToMerge)

用户提供如下格式:“{0} {1}”

mergedColumn 是新列的名称...但它必须能够与将要合并的列之一相同,因为在我的真实世界案例中,我将“name”和“given_names”合并到“名称”...但如果我需要将“街道”、“城市”、“州”、“邮政编码”等合并到名为“地址”的列中,我仍然希望能够使用它。

我认为它的使用方式如下:

MergeColumns("{0} {1}", "姓名", dataTable, "名字", "姓氏");

鉴于上述数据集,我希望结果数据集如下所示:

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() );
}


}

关于c# - 如何合并数据集中的两列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/456568/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com