5

我有一个DataTable不同类型的列。我想要的是DataTable具有相同列名但所有值都是字符串的。也就是说,如果这是第一个:

Name   Age
-----------
John   31
Alice  27
Marge  45

其中 Name 是一String列, Age 是一Int32列,我想要的是:

Name   Age
-----------
John   31
Alice  27
Marge  45

其中 Name 和 Age 都是字符串列。输出表必须包含与输入表相同的值,但每个值都必须转换为字符串。任何人都可以提供有关如何进行此操作的任何见解吗?我想过也许做一些类似的事情

foreach (DataColumn col in inputTable.Columns)
{
    outputTable.Columns.Add(col.ColumnName, typeof(string));

    foreach (DataRow row in inputTable.Rows)
    {
        ...??
    }
}

或者也许有更好或更有效的方法?任何指导将不胜感激。

4

3 回答 3

11

DataTable如果已经有记录,则不能修改列类型。您可以CloneDataTable,然后在克隆表的每一列中修改列类型。稍后您可以导入行。

DataTable dtClone = dt.Clone(); //just copy structure, no data
for (int i = 0; i < dtClone.Columns.Count; i++)
{
    if (dtClone.Columns[i].DataType != typeof(string))
        dtClone.Columns[i].DataType = typeof(string);
}

foreach (DataRow dr in dt.Rows)
{
    dtClone.ImportRow(dr);
}

dtClone将包含字符串的每一列以及原始表中的所有数据dt

于 2014-04-09T18:29:17.157 回答
0

您可以使用名为 toString() 的内置方法。

foreach (DataColumn col in inputTable.Columns)
{
outputTable.Columns.Add(col.ColumnName, typeof(string));

foreach (DataRow row in inputTable.Rows)
{
outputTable.Columns.Add(row.toString());
}
}
于 2014-04-09T18:02:17.600 回答
0

在此代码中,您可以将整个数据集转换为一个字符串。

string ConvertDatasetToString(DataSet Ds)
{
    string OUT = "";
    for (int t = 0; t < Ds.Tables.Count; t++)
    {
        for (int r = 0; r < Ds.Tables[t].Rows.Count; r++)
        {
            for (int c = 0; c < Ds.Tables[t].Columns.Count; c++)
            {
                string s = Ds.Tables[t].Rows[r][c].ToString();
                OUT += s;
            }
        }
    }
    return OUT;
}

如果要将一个数据表转换为一个字符串,可以省略第一个for

于 2014-10-18T09:57:57.420 回答