【问题标题】:print an entire table in C#在 C# 中打印整个表格
【发布时间】:2021-12-21 07:27:40
【问题描述】:

我正在尝试打印 DataTable 的内容,从列标题开始,然后是表元组的内容。

output.Add($"Table : [{dataTable.TableName}]");
string strColumnNames = "";
foreach (DataColumn col in dataTable.Columns)
{
    if (strColumnNames == "")
         strColumnNames = col.ColumnName.PadLeft(col.MaxLength - col.ColumnName.Length);  // (*)
    else strColumnNames = strColumnNames + "|" + 
                          col.ColumnName.PadLeft(col.MaxLength - col.ColumnName.Length);  // (*)
}
output.Add($"[{strColumnNames}]");


foreach (DataRow dataRow in dataTable.Rows)
{
    string temp = "";
    for (int i = 0; i < dataRow.ItemArray.Count(); i++)
    {
        if (i == 0)
            temp = dataRow.ItemArray[i].ToString();                          // (**)
        else temp += "|" + dataRow.ItemArray[i].ToString();                  // (**)
    }
    output.Add($"[{temp}]");
}

该代码中的(*) 部分使用DataColumns 最大长度的MaxLength 属性来获得类似列的输出。

我想在(**)部分做同样的事情,但是我不知道如何访问对应的DataColumn,从dataRow对象开始。

有人有想法吗?
提前致谢

【问题讨论】:

  • 使用dataTable不需要从dataRow开始...dataTable.Columns[i].MaxLength
  • output 是什么?你不会在输出之前将DataTable转换为CSV字符串来简化这个过程吗?

标签: c# datatable datarow datacolumn


【解决方案1】:

您已经拥有可用的dataTable 实例。 dataTable.Columns[i] 应该给你适当的DataColumn

【讨论】:

    【解决方案2】:

    Datatable 已在此处实例化。如果您想打印数据列,您应该使用dataTable.Column[i] 来表示相应的列。

    【讨论】:

      猜你喜欢
      • 2011-02-09
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-01-23
      • 1970-01-01
      相关资源
      最近更新 更多