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

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

ASP环境下轻松实现报表的打印 (转)

发布: 2007-6-30 18:56 | 作者: admin | 来源: | 查看: 30次 | 进入软件测试论坛讨论

领测软件测试网 作者:zcg2000
一、前言
    ASP在电子商务上应用广泛,报表的处理又有一些麻烦。本文介绍了在ASP中利用
本人写的Report Server Page脚本解释器实现报表的显示、打印。
二、准备工作
    (1)安装Visual Reprort Design软件
       Visual Report Design是本人写的一个免费的报表设计器,程序的发行只需要
    安装一个60K的控件即可。
    想要的网友可以到http://go.163.com/reportpro/下载
    (2)设计报表
       通过Visual Report Design 的可视化界面可以生成报表的脚本:mxb.rsp。
三、实现报表的打印、显示
   下面是调用的文档:
    printmx.asp
<%Option Explicit%>
<%
dim ReportName,ret
dim ReportAtl
dim name
set ReportAtl=Session("ReportAtl")
ReportName=Server.MapPath("mxb.rsp")
ret=reportatl.XMLToVBS(ReportName)
if ret=-1 then
  response.write reportatl.ErrorMsg
  response.end
end if

ReportName=Server.MapPath("mxb.vbs")
ret=reportatl.DoScript(ReportName)
if ret=-1 then
  response.write reportatl.ErrorMsg
  set ReportAtl=nothing
  response.end
end if
set ReportAtl=nothing
     %>
     <html>
     <OBJECT id=reportatl classid="clsid:D3F064E5-F4C0-4C52-9E7F-263D96B7EA11" codebase="Report.cab#version=1,0,0,1">
     </OBJECT>
     <script language=vbscript>
dim ret
ret=reportatl.DoPrintReport("mxb.zcg")
if ret=-1 then
  msgbox reportatl.ErrorMsg
end if
     </script>
    </html>     
    
用Visual Report Design 产生的报表脚本mxb.rsp:

<?xml version=@#1.0@# encoding=@#GB2312@# ?>

<!DOCTYPE report SYSTEM @#print_report.dtd@# >

<report name=@#报表@#>

<report_script>

dim rs,con,sql,lsh
dim temp
set con =CreateObject("ADODB.Connection")
con.ConnectionString = "DBQ=c:\report\demo\asp\report.mdb;DRIVER={Microsoft Access Driver (*.mdb)};"
con.open
Set rs =CreateObject("ADODB.Recordset")
sql="SELECT  * FROM cj,student where cj.id=student.id "
rs.open sql,con,1,3

</report_script>

<report_head height=@#12@#>

<text name=@#vfptext@# top=@#4@# left=@#76@# width=@#26@# height=@#5@#  font_name=@#宋体@# font_size=@#14@# font_weight=@#700@# font_italic=@#0@# font_underline=@#0@# >

成绩明细表

</text>

</report_head>

<page_head height=@#6@#>

<line name=@#vfpline@# top=@#0@# left=@#9@# width=@#178@# height=@#0@#  weight=@#131072@#>

</line>

<line name=@#vfpline@# top=@#6@# left=@#9@# width=@#178@# height=@#0@#  weight=@#131072@#>

</line>

<text name=@#vfptext@# top=@#2@# left=@#18@# width=@#6@# height=@#3@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#700@# font_italic=@#0@# font_underline=@#0@# >

姓名

</text>

<text name=@#vfptext@# top=@#2@# left=@#46@# width=@#6@# height=@#3@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#700@# font_italic=@#0@# font_underline=@#0@# >

语文

</text>

<text name=@#vfptext@# top=@#2@# left=@#72@# width=@#6@# height=@#3@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#700@# font_italic=@#0@# font_underline=@#0@# >

数学

</text>

<text name=@#vfptext@# top=@#2@# left=@#99@# width=@#6@# height=@#3@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#700@# font_italic=@#0@# font_underline=@#0@# >

英语

</text>

<text name=@#vfptext@# top=@#2@# left=@#162@# width=@#6@# height=@#3@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#700@# font_italic=@#0@# font_underline=@#0@# >

合计

</text>

<text name=@#vfptext@# top=@#2@# left=@#130@# width=@#6@# height=@#3@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#700@# font_italic=@#0@# font_underline=@#0@# >

平均

</text>

</page_head>

<page_body height=@#8@#>

<text name=@#vfptext@# top=@#2@# left=@#15@# width=@#25@# height=@#4@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#100@# font_italic=@#0@# font_underline=@#0@# >

<report_script>

Report.Write cstr(rs("xm"))

</report_script>

</text>

<text name=@#vfptext@# top=@#2@# left=@#45@# width=@#18@# height=@#4@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#100@# font_italic=@#0@# font_underline=@#0@# >

<report_script>

Report.Write cstr(rs("yw"))

</report_script>

</text>

<text name=@#vfptext@# top=@#2@# left=@#71@# width=@#18@# height=@#4@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#100@# font_italic=@#0@# font_underline=@#0@# >

<report_script>

Report.Write cstr(rs("sx"))

</report_script>

</text>

<text name=@#vfptext@# top=@#2@# left=@#98@# width=@#18@# height=@#4@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#100@# font_italic=@#0@# font_underline=@#0@# >

<report_script>

Report.Write cstr(rs("yy"))

</report_script>

</text>

<text name=@#vfptext@# top=@#2@# left=@#130@# width=@#18@# height=@#4@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#100@# font_italic=@#0@# font_underline=@#0@# >

<report_script>

Report.Write cstr((rs("yw")+rs("sx")+rs("yy"))/3)

</report_script>

</text>

<text name=@#vfptext@# top=@#2@# left=@#162@# width=@#18@# height=@#4@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#100@# font_italic=@#0@# font_underline=@#0@# >

<report_script>

Report.Write cstr(rs("yw")+rs("sx")+rs("yy"))

</report_script>

</text>

</page_body>

<page_foot height=@#7@#>

<text name=@#vfptext@# top=@#2@# left=@#12@# width=@#13@# height=@#3@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#100@# font_italic=@#0@# font_underline=@#0@# >

<report_script>

report.write "打印日期:"+formatdatetime(date(),1)

</report_script>

</text>

<text name=@#vfptext@# top=@#2@# left=@#137@# width=@#50@# height=@#3@#  font_name=@#宋体@# font_size=@#9@# font_weight=@#100@# font_italic=@#0@# font_underline=@#0@# >

共%Pages%页,第%Page%页

</text>

<line name=@#vfpline@# top=@#0@# left=@#8@# width=@#178@# height=@#0@#  weight=@#131072@#>

</line>

</page_foot>

<report_script>

do while not rs.eof
   page_body()
   rs.movenext
  loop
  rs.close
  set rs=nothing
  con.close
  set con=nothing

</report_script>



</report>

四、其它信息
   这是本人第一个开发工具,做得不好请指教
   详细情况可以看:http://go.163.com/reportpro/
   关于在ASP下使用的详细例子可以看c:\demo\asp/目录


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


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

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