请教vb.net中datagridview导出excel的相关问题

liuxg6 2008-07-24 10:02:22
在vb.net中遇到一个问题,请教高手如何解决,谢谢!
vb.net中datagridview另存为excel文件后一些数字数据导出后格式不正确,主要有以下问题:
1、长的数字保存excel后变成了科学计数法,如我的单据号200807000123到excel后2.00807E+11
2、以零开头的数字到excel中零没有了,如我的物料代码012345到excel后成了12345
另存为excel的方法是从网上找的:
模块中声明:
Public Sub DcExcel(ByVal DGV As DataGridView)
'把datagridview中的数据导出到excel
Dim wapp As New Microsoft.Office.Interop.Excel.Application
Dim wsheet As Microsoft.Office.Interop.Excel.Worksheet
Dim wbook As Microsoft.Office.Interop.Excel.Workbook

On Error Resume Next

wapp.Visible = True
wbook = wapp.Workbooks.Add()
wsheet = wbook.ActiveSheet

Dim iX As Integer
Dim iY As Integer
Dim iC As Integer

For iC = 0 To DGV.Columns.Count - 1
wsheet.Cells(1, iC + 1).Value = DGV.Columns(iC).HeaderText
wsheet.Cells(1, iC + 1).Font.Bold = True
Next

wsheet.Rows(2).select()
For iX = 0 To DGV.Rows.Count - 1
For iY = 0 To DGV.Columns.Count - 1
wsheet.Cells(iX + 2, iY + 1).value = DGV(iY, iX).Value.ToString
Next
Next
End Sub
导出按钮代码:
Call DcExcel(DataGridView1)
...全文
742 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
于之 2009-01-12
  • 打赏
  • 举报
回复
以上的导出生成Excel慢吗?
我估计几千条也会慢得要命!
sjxwb 2008-07-25
  • 打赏
  • 举报
回复
快速的导出方法是用SQL像操作数据库那样来操作Excel
对。但是全导成文本型的,这是美中不足。
ejoe313 2008-07-24
  • 打赏
  • 举报
回复
仅供参考:


Select Case dc.DataType.ToString
Case "System.String"
xlSheet.Cells(rowindex, colindex).NumberFormat = "@"
Case "System.Decimal"
xlSheet.Cells(rowindex, colindex).NumberFormat = "#,##0"
'xlSheet.Cells(rowindex, colindex).NumberFormat = "#,##0.0#"
Case "System.DateTime"
xlSheet.Cells(rowindex, colindex).NumberFormat = "YYYY-MM-DD HH:MM:SS"
End Select
ejoe313 2008-07-24
  • 打赏
  • 举报
回复
wsheet.Cells(iX + 2, iY + 1).value = DGV(iY, iX).Value.ToString
后面加一句
wsheet.Cells(iX + 2, iY + 1).NumberFormat = "@"
格式化一下试试
ejoe313 2008-07-24
  • 打赏
  • 举报
回复
参看2楼,根据各列的数据类型来格式化Excel;

快速的导出方法是用SQL像操作数据库那样来操作Excel,网上有例子的……
liuxg6 2008-07-24
  • 打赏
  • 举报
回复
上面第五行错了,应该是
wsheet.Cells(iX + 2, iY + 1).NumberFormat = "###"


我发的回复怎么不能修改?
liuxg6 2008-07-24
  • 打赏
  • 举报
回复
刚才按照两位的方法试了一下,如果加上:
wsheet.Cells(iX + 2, iY + 1).NumberFormat = "@"
没有变化
后来自己修改成 :
wsheet.Cells(iX + 2, iY + 1).NumberFormat = "@"
上面的问题到是可以解决,但是其他金额数据也就变成了没有小数点的了!
能不能通过修改datagridview中的数据属性解决?如何定义datagridview中列的数据类型?
还有就是按照我上面说的导入excel的方法,是打开一个excel文件然后将数据写入,速度太慢,如何实现直接另存为excel文件?
本人初学,希望回答的详细些,谢谢指教!
rainbowsoftware 2008-07-24
  • 打赏
  • 举报
回复
把单元格格式设置一下
vb.net操作DataGridView控件的用法的集合,包括: 1. DataGridView当前的单元格属性取得、变更 2. DataGridView编辑属性 3. DataGridView最下面一列新追加行非表示 4. DataGridView判断当前选行是否为新追加的行 5. DataGridView删除行可否设定 6. DataGridView行列不表示和删除 DataGridView控件用法合集(二) 7. DataGridView行列宽度高度设置为不能编辑 8. DataGridView行高列幅自动调整 9. DataGridView指定行列冻结 10. DataGridView列顺序变更可否设定 11. DataGridView行复数选择 12. DataGridView选择的行、列、单元格取得 DataGridView控件用法合集(三) 13. DataGridView指定单元格是否表示 14. DataGridView表头部单元格取得 15. DataGridView表头部单元格文字列设定 16. DataGridView选择的部分拷贝至剪贴板 17.DataGridView粘贴 18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息) DataGridView控件用法合集(四) 19. DataGridView的ContextMenuStrip属性 20. DataGridView指定滚动框位置 21. DataGridView手动追加列 22. DataGridView全体分界线样式设置 23. DataGridView根据单元格属性更改显示内容 24. DataGridView新追加行的行高样式设置る 25. DataGridView新追加行单元格默认值设置 DataGridView输入错误数据的处理(五) 26. DataGridView单元格数据错误标签表示 27. DataGridView单元格内输入值正确性判断 28. DataGridView单元格输入错误值事件的捕获 DataGridView控件用法合集(六) 29. DataGridView行排序(点击列表头自动排序的设置) 30. DataGridView自动行排序(新追加值也会自动排序) 31. DataGridView自动行排序禁止情况下的排序 32. DataGridView指定列指定排序 DataGridView控件用法合集(七) 33. DataGridView单元格样式设置 34. DataGridView文字表示位置的设定 35. DataGridView单元格内文字列换行 36. DataGridView单元格DBNull值表示的设定 37. DataGridView单元格样式格式化 38. DataGridView指定单元格颜色设定 39. DataGridView单元格文字字体设置 40. DataGridView根据单元格值设定单元格样式 DataGridView控件用法合集(八) 41. DataGridView设置单元格背景颜色 42. DataGridView行样式描画 43. DataGridView显示行号 44. DataGridView焦点所在单元格焦点框不显示的设定 DataGridView控件用法合集(九) 45. DataGridView显示选择框CheckBox 46. DataGridView显示下拉框ComboBox 47. DataGridView单击打开下拉框 48. DataGridView显示按钮 49. DataGridView显示链接 50. DataGridView显示图像 DataGridView控件用法合集(十) 51. DataGridView编辑单元格控件取得 52. DataGridView输入自动完成 53. DataGridView单元格编辑时键盘KEY事件取得 54. DataGridView下拉框(ComboBox)单元格编辑时事件取得 55. DataGridView下拉框(ComboBox)单元格允许文字输入设定 DataGridView控件用法合集(十一) 56. DataGridView根据值不同在另一列显示相应图片 57. DataGridView显示进度条(ProgressBar) 58. DataGridView添加MaskedTextBox DataGridView控件用法合集(十二) 59. DataGridViewEnter键按下焦点移至旁边的单元格 60. DataGridView行集合化(Group)

16,718

社区成员

发帖
与我相关
我的任务
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
  • VB.NET
  • 水哥阿乐
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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