datagridview 导入 excel 出现空白单元格的问题??!!

a09002412 2009-06-10 11:06:45
Dim strCon As String = " Provider = Microsoft.Jet.OLEDB.4.0 ;Data Source = " & fileName & " ;Extended Properties ='Excel 8.0;IMEX=1;'"
Dim myConn As New System.Data.OleDb.OleDbConnection(strCon)
Dim strCom As String = " SELECT * FROM [sheet1$] "
Dim myCommand As New System.Data.OleDb.OleDbDataAdapter(strCom, myConn)
Dim dt As New System.Data.DataTable()
DataGridView.AllowUserToAddRows = False
myCommand.Fill(dt)
Me.DataGridView.DataSource = dt

代码如上:

在excel文档中。首位为0的数字,导进datagridview后,就为空白格,我查了下资料:IMEX=1,可以把数字作为文本导入。

这里非常奇怪的是:我把excel文档中改了下数字导入(随便怎么改),可以正常导入。然后再把改过的数字改回来,再导入。。。竟然也能正常导入了,不会出现之前的:首位为0的数字导入为空白格的问题。


我晕了,谁教我下。。。

...全文
193 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
susanjuly 2010-08-26
  • 打赏
  • 举报
回复
??????
a09002412 2009-06-10
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 outou 的回复:]
不是变EXCEL单元格的类型,而是导入DataGridView时设定类型。

[/Quote]

是设定DataGridView的类型为字符串吗??
outou 2009-06-10
  • 打赏
  • 举报
回复
不是变EXCEL单元格的类型,而是导入DataGridView时设定类型。
a09002412 2009-06-10
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 outou 的回复:]
在导入时,就好把每个单元格的数据都变成文字列就不会有问题了。

[/Quote]

已经是excel中已经改成了文本格式了。。

还是这种情况。。。
outou 2009-06-10
  • 打赏
  • 举报
回复
在导入时,就好把每个单元格的数据都变成文字列就不会有问题了。
a09002412 2009-06-10
  • 打赏
  • 举报
回复
为啥没人回啊。。。
a09002412 2009-06-10
  • 打赏
  • 举报
回复
顶顶。。求助高手~~~
a09002412 2009-06-10
  • 打赏
  • 举报
回复
[Quote=引用 12 楼 outou 的回复:]
已收到,确认完后,告诉你结果。
[/Quote]
好的!!
谢谢
outou 2009-06-10
  • 打赏
  • 举报
回复
已收到,确认完后,告诉你结果。
a09002412 2009-06-10
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 outou 的回复:]
不可能呀,把你的代码和EXCEL文件发给我。bingning@bingning.net
[/Quote]


已经发送。。。请查收邮件!!

谢谢啦,多指教的。。。
outou 2009-06-10
  • 打赏
  • 举报
回复
不可能呀,把你的代码和EXCEL文件发给我。bingning@bingning.net
a09002412 2009-06-10
  • 打赏
  • 举报
回复
老大,没用啊,我现在检测到excel中首位为0的数字,读过来的数据是DBNULL
但是只要在数字所在的那一列改动下再保存,就可以顺利读取所以包括首位为0的数字。

到底怎么回事呢?????
a09002412 2009-06-10
  • 打赏
  • 举报
回复
老大,没用啊,我现在检测到excel中首位为0的数字,读过来的数据是DBNULL
但是只要在数字所在的那一列改动下再保存,就可以顺利读取所以包括首位为0的数字。

到底怎么回事呢?????
outou 2009-06-10
  • 打赏
  • 举报
回复
是的。
参考http://bingning.net/free/source/programing/index.html我写的EXCEL自定义类。
与6.0版相比,控件6.01版的主要更改如下: 1、解决6.0版在XP及Windows Server 2008等操作系统下打印预览及打印不正确的问题(第1页正常,其他各页全部是空白)。 控件主要功能: 1、强大的DataGridView打印功能,不仅可以以多种形式(普通打印、分栏打印、跨页打印、工资条打印)打印DGV表格,基本上能完全按DGV控件本身设置的格式如字体、字号、背景颜色、前景颜色、单元格对齐方式等打印出来,文字图像都可以打印,而且是完全根据表格当前的显示顺序进行打印的,基本上做到了所见即所得的打印。 2、报表设计功能。报表模板设计组件EasyReport可以设计普通报表、分组报表、套打模板等,以DataGridView为数据源。控件的位置以毫米为计量单位,定位准确,很适合套打单据设计。 3、图表打印功能。5.2版控件新增了一个Chartlet的组件,使用非常方便,可以生成柱形图、饼图、折线图等多种图形,而且可以设置2D或3D效果,既可以在打印控件中打印出来,也可以在Graphics对象中显示。 4、文本打印输出功能,控件提供多个文本打印重载函数,打印文本时,如果需要,控件会自动换行和换页打印输出。还增加了以指定行间距及字符间距打印文本的功能,可以用固定行距,也可以用单倍或多倍行距打印文本。 5、绘图功能,基本上.NET的GDI+的绘图函数(如直线、矩形、路径、多边形、曲线等)都有,只有个别函数的名称有点区别。 6、支持同一文档多种版面格式打印(类似于Word中的节的功能):对同一份文档,不同的页面可以设置不同的格式(纸张大小、纸张方向、页边距),只需要在新增一页时在NewPage方法中指定要使用的页面格式即可,使用非常简单。 7、报表文件保存功能。本控件允许将当前打印预览的内容保存为报表文件,以后使用本控件重新打开该报表文件即可重现原来保存报表时的打印内容。 8、数据导出功能,可以将DataGridView导出为Excel\PDF\RTF\HTML文件,5.7版控件使用开源的NPOI导出Excel,速度非常快,效果非常好。 9、强大的容器控件打印功能(DrawPanel函数)。借助该函数,您只需要在您的容器控件中设计好要打印的内容及打印内容的相对位置,控件轻松帮你打印出来(如果超过一页,控件会自动换页续打)。 10、5.6版新增的SimpleReport组件允许您在一个方案文件中管理多个打印方案,在打印预览时能自由在各个打印方案之间切换。 11、RichTextBox控件的RTF文本打印功能。 12、页眉页脚中既可打印文字,也可打印图像,或者即打印图像又打印输出文字。 13、多表头(跨行跨列的复杂表头)打印功能,多表头组件支持多表头显示与打印、单元格内容的合并显示、打印与导出。 14、自定义纸张支持功能。 15、直接打印窗口中的TreeView控件功能。 16、打印窗口中的ListView功能。 17、斜线表头打印功能。 18、各种条形码(包括二维码)打印功能。 19、5.7版控件增加了使用开源的NPOI从Excel文件(支持2003与2007格式)中导入数据到DataGridView的功能,以及DataGridView的复制与粘贴功能。

17,740

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 .NET Framework
社区管理员
  • .NET Framework社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧