• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

在.NET环境下将报表数据导出Excel和Word

发布: 2008-4-23 10:38 | 作者: 网络转载 | 来源: 网络转载 | 查看: 175次 | 进入软件测试论坛讨论

领测软件测试网  在VB6开发环境下,本人使用EXCEL作过报表,在.NET环境下开发,本人使用水晶报表。但VB.NET同样可以将报表导出到EXCEL和WORD进行输出,制作出专业水平的报表。

  具体操作如下:(注:首先需添加引用,选择COM,选择Microsoft Word 10.0 Object Library和Microsoft Excel 10.0 Object Library组件)

  1.先创建一个DataTable,作为数据来源,也可以另将其它的数据源。

  Private Function CreaTable() As DataTable
  Dim dt As New DataTable()
  dt.Columns.Add("列1", GetType(String))
  dt.Columns.Add("列2", GetType(Integer))
  dt.Columns.Add("列3", GetType(String))
  dt.Columns.Add("列4", GetType(String))
  Dim row, row1 As DataRow
  row = dt.NewRow()
  row!列1 = "行1"
  row!列2 = 1
  row!列3 = "d"
  row!列4 = "a"
  dt.Rows.Add(row)
  row1 = dt.NewRow()
  row1!列1 = "行2"
  row1!列2 = 12
  row1!列3 = "b"
  row1!列4 = "c"
  dt.Rows.Add(row1)
  Return dt
  End Function

  2.将表中的内容导出到Excel

  Dim xlApp As New Excel.Application()
  Dim xlBook As Excel.Workbook
  Dim xlSheet As Excel.Worksheet
  Dim rowIndex, colIndex As Integer
  rowIndex = 1
  colIndex = 0
  xlBook = xlApp.Workbooks().Add
  xlSheet = xlBook.Worksheets("sheet1")
  Dim Table As New DataTable()
  Table = CreaTable()
  '将所得到的表的列名,赋值给单元格
  Dim Col As DataColumn
  Dim Row As DataRow
  For Each Col In Table.Columns
  colIndex = colIndex + 1
  xlApp.Cells(1, colIndex) = Col.ColumnName
  Next
  '得到的表所有行,赋值给单元格
  For Each Row In Table.Rows
  rowIndex = rowIndex + 1
  colIndex = 0
  For Each Col In Table.Columns
  colIndex = colIndex + 1
  xlApp.Cells(rowIndex, colIndex) = Row(Col.ColumnName)
  Next
  Next
  With xlSheet
  .Range(.Cells(1, 1), .Cells(1, colIndex)).Font.Name = "黑体"
  '设标题为黑体字
  .Range(.Cells(1, 1), .Cells(1, colIndex)).Font.Bold = True
  '标题字体加粗
  .Range(.Cells(1, 1), .Cells(rowIndex, colIndex)).Borders.LineStyle = 1
  '设表格边框样式
  End With
  With xlSheet.PageSetup
  .LeftHeader = "" & Chr(10) & "&""楷体_GB2312,常规""&10公司名称:" ' & Gsmc
  .CenterHeader = "&""楷体_GB2312,常规""公司人员情况表&""宋体,常规""" & Chr(10) & "&""楷体_GB2312,常规""&10日 期:"
  .RightHeader = "" & Chr(10) & "&""楷体_GB2312,常规""&10单位:"
  .LeftFooter = "&""楷体_GB2312,常规""&10制表人:"
  .CenterFooter = "&""楷体_GB2312,常规""&10制表日期:"
  .RightFooter = "&""楷体_GB2312,常规""&10第&P页 共&N页"
  End With
  xlApp.Visible = True

  

延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/

TAG: net 环境 数据 Excel NET Word

21/212>

关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网