【问题标题】:Datagridview column value displaying issueDatagridview 列值显示问题
【发布时间】:2017-07-16 01:04:33
【问题描述】:

我无法解决以下问题:

  • 连接到 Excel(oledb 连接)
  • 获取所有数据到datagridview

从 Excel 获取的示例源(Col1 到 Col3 Excel 属性是“常规”,Col4 是特定于日期的):

Col1    Col2    Col3    Col4
Text1   1.5 288.77  3/1/2013
Text2   1.3 352.47  3/1/2013
Text3   1a  206.93  3/1/2013
Text4   1   206.93  3/1/2013
Text5   1   206.93  3/1/2013
  • 一旦数据在datagridview (DataGridView.AutoGenerateColumns=True),它似乎需要 授予Col2 仅包含整数并且不显示 非整数的单元格值。

从 datagridview 获取的示例:

   Col1 Col2    Col3    Col4
    Text1   1.5 288.77  3/1/2013
    Text2   1.3 352.47  3/1/2013
    Text3       206.93  3/1/2013
    Text4   1   206.93  3/1/2013
    Text5   1   206.93  3/1/2013
  • 实际问题是我正在验证 datagridview 中的数据 针对 XML 文件,并证明提供用户 rowID 的日志 和实际的源值。我似乎无法获得相同的价值 的数据网格视图。
  • 到目前为止,我发现的唯一部分解决方案是显式 将所有 Excel 字段转换为文本,但这显然会弄乱一些 字段(例如:日期字段)。

如何获取 datagridview 中的所有 SOURCE FILE 值,然后执行所有后续数据验证任务?

【问题讨论】:

  • 连这个都看不懂。稍微格式化一下。
  • 对格式问题表示歉意 - 现在应该已修复。

标签: c# excel datagridview


【解决方案1】:

您似乎正试图仅将 Excel 原始数据(因为它在 Excel 工作表中格式化)提取到 datagridview 以进行显示,然后执行额外的数据验证。 我建议使用下面的混合列连接字符串示例(IMEX):

strConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;" +
                                        "Data Source=" + strFilePath + ";Jet OLEDB:Engine Type=5;Extended Properties='Excel 12.0;HDR=NO;IMEX=1'";

【讨论】:

  • 谢谢,这正是我所需要的——按原样获取数据,然后继续进行所需的任何验证。
【解决方案2】:

我建议创建一个包含所需类型的数据列的 DataTable,然后将数据放入 DataTable。最后,将DataTable绑定到DataGridview

【讨论】:

  • 谢谢 Tarik,这里有一个进一步的说明——我将它用于不同类型的数据,所以它应该是动态的。我无法设置确切的列数和类型,因为这些可能因来源而异。
  • 有没有办法提前确定列数据类型?
  • 我的意思是,你能在运行时从 Excel 读取数据时确定列类型吗?
【解决方案3】:

read-a-excel-file-with-sheet-wise-into-dataset-using-csharp 可能对你有帮助。 你真的不需要知道文件中的数据来构建一个可用的表。

【讨论】:

  • 这是读取 Excel 文件的有效方式,但 Ventsislav 的回答正是我所需要的。谢谢。
  • 没问题,很高兴你得到了你需要的东西。
猜你喜欢
  • 1970-01-01
  • 2014-03-09
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-09-28
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多