欢迎光临
我们一直在努力

使用XML+VBS技术在ASP中实现报表的打印

建站超值云服务器,限时71元/月

一、前言

asp在电子商务上应用广泛,报表的处理又有一些麻烦。本文介绍了在asp中利用

本人写的report server page脚本解释器实现报表的显示、打印。

二、准备工作

(1)安装visual reprort design软件

visual report design是本人写的一个免费的报表设计器,程序的发行只需要

安装一个控件即可。

想要的网友可以到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/目录

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 使用XML+VBS技术在ASP中实现报表的打印
分享到: 更多 (0)

相关推荐

  • 暂无文章