上一篇:关于在页面中解决打印的几个问题 >>
使用XML+VBS技术在ASP中实现报表的打印
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/目录
下一篇:关于客户端用ASP参生报表(高级篇) >>
相关文章:
- · 动感首页更新实现之四 ------ 首页显示篇
- · 动感首页更新实现之三 ------ 数据库链接篇
- · 动感首页更新实现之二 ------ 首页保存篇
- · 动感首页更新实现之一 ------ 首页添加篇
- · 完整的访问统计程序(三 应用篇)
- · 完整的访问统计程序(二 程序篇)
- · 完整的站点访问统计系统(一:数据库篇)
- · 支持中文的无组件文件上传:upload.inc
- · 支持中文的无组件文件上传:示例
- · 对数据库中的记录用上一条下一条显示(三)
- · 对数据库中的记录用上一条下一条显示(二)
- · 对数据库中的记录用上一条下一条显示(一)
- · 利用ASP脚本制作异步装载的树形结构(二)
- · 利用ASP脚本制作异步装载的树形结构(一)
- · 不能ASP图像组件来生成图像的ASP计数器程序(三)
- · 不能ASP图像组件来生成图像的ASP计数器程序(二)
- · 不能ASP图像组件来生成图像的ASP计数器程序(一)
- · ASP技术在论坛中的运用(八)(吐血推荐!!!!)
- · ASP技术在论坛中的运用(七)(吐血推荐!!!!)
- · ASP技术在论坛中的运用(六)(吐血推荐!!!!)
- · ASP技术在论坛中的运用(五)(吐血推荐!!!!)
- · ASP技术在论坛中的运用(四)(吐血推荐!!!!)
- · ASP技术在论坛中的运用(三)(吐血推荐!!!!)
- · ASP技术在论坛中的运用(二)(吐血推荐!!!!)
- · ASP技术在论坛中的运用(一)(吐血推荐!!!!)
- · ASP环境下邮件列表功能的实现 (四)(推荐)
- · ASP环境下邮件列表功能的实现 (三)(推荐)
- · ASP环境下邮件列表功能的实现 (二)(推荐)
- · ASP环境下邮件列表功能的实现 (一)(推荐)
- · 一个BBS的源代码(六)
- · 一个BBS的源代码(五)
- · 一个BBS的源代码(四)
- · 一个BBS的源代码(三)
- · 一个BBS的源代码(二)
- · 一个BBS的源代码(一)
- · 如何使用ASP在自己的网站建立投票机制(二)
- · 如何使用ASP在自己的网站建立投票机制(一)
- · 如何用ASP编写网站统计系统四
