首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 网页制作-> Javascript教程
一个通用的Datagrid导出Excel打印的源函数-.NET教程,数据库应用
作者:网友供稿 点击:74
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 
一个通用的datagrid导出excel打印的源函数
闲暇之余,写成函数,供新人研究学习



power by:landlordh
列宽默认为datagird的tablestyles(0)列宽的五分之一
g2e(dg1)


public function g2e(byval dg as datagrid)
dim dt as new datatable
try
dt = ctype(dg.datasource, datatable)
catch ex as exception
msgbox(ex.message)
exit function
end try
dim total_col as integer = dt.columns.count
dim total_row as integer = dt.rows.count
if total_col < 1 or total_row < 1 then
msgbox("没有可供导入的数据!", msgboxstyle.information, "系统提示")
exit function
end if

killexcel()

要先在引用中添加excel组件
dim xlapp as new excel.application
dim xlbook as excel.workbook
dim xlsheet as excel.worksheet

try
gc.collect()
xlbook = xlapp.workbooks().add
xlsheet = xlbook.worksheets("sheet1")
xlapp.visible = true

try
with xlsheet.pagesetup
.rightmargin = 1
.leftmargin = 1
.centerhorizontally = true
.centerheader = "&24 报表"
.rightfooter = "&p of &n"
end with
catch ex as exception
msgbox(ex.tostring)
exit function
end try

dim col as integer
dim row as integer
dim st_row as integer = 5 数据列头开始行,(列头)
dim truecol as integer = 0
for col = 0 to total_col - 1
if dg.tablestyles.item(0).gridcolumnstyles.item(col).width > 0 then truecol += 1
next

dim titlearray(4, 0) as object
dim headerarray(0, truecol - 1) as object
dim dataarray(total_row - 1, truecol - 1) as object

titlearray(0, 0) = "to:"
titlearray(1, 0) = "form:"
titlearray(2, 0) = ""
titlearray(3, 0) = ""
xlsheet.range("a1").resize(4, 1).value = titlearray

dim i as integer = 0
for col = 0 to total_col - 1
if dg.tablestyles.item(0).gridcolumnstyles.item(col).width > 0 then
i += 1
headerarray(0, i - 1) = dt.columns(col).columnname
设列宽,默认为datagird列宽的五分之一
xlsheet.cells(st_row, i).columnwidth = dg.tablestyles.item(0).gridcolumnstyles.item(col).width / 5
end if
next
xlsheet.range("a" & st_row).resize(st_row, truecol).value = headerarray

for row = 0 to total_row - 1
i = 0
for col = 0 to total_col - 1
if dg.tablestyles.item(0).gridcolumnstyles.item(col).width > 0 then
i += 1
dataarray(row, i - 1) = dt.rows(row).item(col)
end if
next
next
xlsheet.range("a" & st_row + 1).resize(total_row, truecol).value = dataarray

with xlsheet
.range(.cells(st_row, 1), .cells(st_row, truecol)).font.bold = true
.range(.cells(st_row, 1), .cells(st_row, truecol)).horizontalalignment = 3
.range(.cells(st_row, 1), .cells(total_row + st_row, truecol)).borders.linestyle = 1
设置数据区第一列到第二列为居中
.range(.cells(st_row, 1), .cells(total_row + st_row, 2)).horizontalalignment = 3
end with

xlapp.activeworkbook.printpreview()
catch ex as exception
xlsheet = nothing
xlapp.displayalerts = false
xlbook.runautomacros(excel.xlrunautomacro.xlautoclose)
xlbook.close()
xlbook = nothing
xlapp.quit()
xlapp.displayalerts = true
xlapp = nothing
gc.collect()
msgbox(ex.tostring)
exit function
end try
xlsheet = nothing
xlapp.displayalerts = false
xlbook.runautomacros(excel.xlrunautomacro.xlautoclose)
xlbook.close()
xlbook = nothing
xlapp.quit()
xlapp.displayalerts = true
xlapp = nothing
gc.collect()
end function



文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·基于cpld的数字触发电路的设计
·消息队列(Message Queue)简介及其使用-.NET教程,评论及其它
·session_register()出错的解决办法-PHP教程,其它文章
·卫星通信中tcp协议分析改进方法研究
·漫谈Java语言的接口与类型安全-JSP教程,Java技巧及代码
·SQL SERVER2005連接字串中的@3/29-.NET教程,数据库应用
·自创]JCreator安装学习使用方法-数据库专栏,SQL Server
·ASP.NET 数据绑定常用代码-.NET教程,Asp.Net开发
·如何在J2ME的低级界面中轻松实现各种文字的自然分行显示-JSP教程,J2ME开发
·通信设备pac模块式开关电源的原理与维修
最新文章
·photoshop将肖像照片处理为铅笔素描_photoshop教程
·个人网站做联盟广告的几点经验_网赚技巧
·适合与不适合做google adsense的站_网赚技巧
·gg网赚之:怎么样利用e文站轻松月入100刀_网赚技巧
·黄明明归国创业寻觅伙伴:人品好是必要条件_站长访谈
·最普通的7种软文类型_站长访谈
·第九城市ceo朱骏 网海中闯出一片天_站长访谈
·反波访谈:听keso乱弹琴_站长访谈
·人性和互联网_站长心得
·大型网站常用的五种推广方法_站长心得
相关主题
  • 一个通用的分页类_asp.net技巧
  • 一个通用的表单验证程序-网页设计,HTML/CSS
  • 一个通用的保护ASP系统的方法-ASP教程,安全加密
  • 一个通用的连接池Bean-JSP教程,资料/其它
  • 一个通用的JSP分页程序-JSP教程,Jsp/Servlet
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭