VB利用DataReport做报表详解.docVIP

  1. 1、本文档共46页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
?? VB利用DataReport做报表 首先介绍一下DataReport对象的几个常用属性。一是DataSource,用于设置一个数据源,通过该数 据源,数据使用者被绑定到一个数据库;二是DataMember,从DataSource提供的几个数据成员中设 置一个特定的数据成员;三是LeftMargin、RightMargin、TopMargin、BottomMargin等,用于指定 报表的左右上下的页边距;四是Sections,即DataReport的报表标头、页标头、细节、页脚注、报 表脚注5个区域,如果加上分组(可以有多层分组),则增加一对区域,即分组标头、分组脚注。其 中DataSource一般是一个数据环境或是ADODB.Connection类型的变量,而DataMember则对应数据环 境中的Command或是ADODB.RecordSet类型的变量,推荐使用数据环境及Command,页边界大家肯定 都很清楚,下面我主要介绍以下Sections,这也是DataReport的精髓所在。 Sections是一个集合,您可以为每一个Section指定名称,也可以用其缺省的索引,从上到下 依次为1、2…。每个Section均有Height和Visible属性,您可以在一定条件下使一个Section不可 见。在Section中可以放置各种报表控件,其中RptLabel、RptImage、RptShape和RptLine可以放在 任意的Section中,用于输出各种文字、图形及表格线;RptTextBox只能放在细节中,一般用于绑 定输出DataMemeber提供的数据字段;RptFunction只能被放置在分组注脚中,用于输出使用各种内 置函数计算出的合计、最大值、最小值、平均值、记数等等。上述报表控件中常用公共属性有用于 控制位置及高度宽度的Top、Left、Height、Width和控制可见性的Visible;其中RptTextBox还有 DataField、DataMember、DataFormat及Font属性;其他属性不再多说。 然后介绍一下我的使用经验。一是对想控制的报表控件按类型有规律的命名;二是用RptShape 的矩形框做表格线框,比用RptLine画框省事多了,只有斜线才使用RptLine;三是报表标题及报表 中的表头文字、日期及页码用RptLabel,其中Caption属性支持转义字符,%D为长格式日期,%d为 短格式日期,%P为总页数,%p为当前页码;四是对固定报表在设计窗口直接将报表控件摆放到位, 对于活报表,应首先考虑报表最大的情形,将足够的控件分别放置在不同区域,位置大小可以不必 深究,然后在报表输出前用VBA代码对所有控件的属性进行调整,包括位置、高度、宽度、字体、 对齐方式、显示格式、可见性等等,相应的对Section也应根据情况调整其高度和可见性。 最后用一个实例模板来说明其使用方法。 连接数据库 With 数据环境.rsCommand名 If .State = adStateOpen Then .Close .Source = SQL语句 .Open 打开想输出的数据库数据项以便输出 End With With 报表名 .DataSource=数据环境 .DataMember=Command名 这两行也可固定设好而不必每次设置 设置页表头部分(RpttLabel…为报表控件名) .Sections(2).Controls(RptLabelPage).Caption = 共%P页第%p页 .Sections(2).Controls(RptLabelDate).Caption = 打印日期:%D .Sections(3).Controls(RptLabel1).Left=… … 设置细节部分(RptShapeX、RptTextBoxX为报表控件名) .Sections(3).Controls(RptShape1).Left=… .Sections(3).Controls(RptShape1).Top=… .Sections(3).Controls(RptShape1).Height=… .Sections(3).Controls(RptShape1).Width=… .Sections(3).Controls(RptTextBox1).DataMember=Command名 .Sections(3).Controls(RptTextBox1).DataField=字段1 .Sections(3).Controls(RptTextBox1).Font.Name=… … .Sections(3).Controls(RptShapeN).

文档评论(0)

185****7617 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档