日本国产亚洲-日本国产一区-日本国产一区二区三区-日本韩国欧美一区-日本韩国欧美在线-日本韩国欧美在线观看

當(dāng)前位置:雨林木風(fēng)下載站 > 技術(shù)開(kāi)發(fā)教程 > 詳細(xì)頁(yè)面

VB6中用DataReport做報(bào)表

VB6中用DataReport做報(bào)表

更新時(shí)間:2022-05-05 文章作者:未知 信息來(lái)源:網(wǎng)絡(luò) 閱讀次數(shù):

我不是VB熟練工,最近剛剛用VB做完一個(gè)程序,其中控制部分沒(méi)費(fèi)太大周折,倒是報(bào)表部分頗讓我費(fèi)了一翻腦筋。在網(wǎng)上找了半天,也沒(méi)找到關(guān)于VB6的 DataReport的詳細(xì)介紹,于是想借鑒"前輩"們的經(jīng)驗(yàn),用CrystalReport或EXCEL,感覺(jué)也不省勁,于是決定回頭再去"啃"DataReport,別說(shuō),還真讓有所收獲,下面就簡(jiǎn)單的介紹一下我的體會(huì),希望對(duì)大家能有所幫助。

  首先介紹一下DataReport對(duì)象的幾個(gè)常用屬性。一是DataSource,用于設(shè)置一個(gè)數(shù)據(jù)源,通過(guò)該數(shù)據(jù)源,數(shù)據(jù)使用者被綁定到一個(gè)數(shù)據(jù)庫(kù);二是DataMember,從DataSource提供的幾個(gè)數(shù)據(jù)成員中設(shè)置一個(gè)特定的數(shù)據(jù)成員;三是LeftMargin、RightMargin、TopMargin、BottomMargin等,用于指定報(bào)表的左右上下的頁(yè)邊距;四是Sections,即DataReport的報(bào)表標(biāo)頭、頁(yè)標(biāo)頭、細(xì)節(jié)、頁(yè)腳注、報(bào)表腳注5個(gè)區(qū)域,如果加上分組(可以有多層分組),則增加一對(duì)區(qū)域,即分組標(biāo)頭、分組腳注。其中DataSource一般是一個(gè)數(shù)據(jù)環(huán)境或是ADODB.Connection類型的變量,而DataMember則對(duì)應(yīng)數(shù)據(jù)環(huán)境中的Command或是ADODB.RecordSet類型的變量,推薦使用數(shù)據(jù)環(huán)境及Command,頁(yè)邊界大家肯定都很清楚,下面我主要介紹以下Sections,這也是DataReport的精髓所在。

  Sections是一個(gè)集合,您可以為每一個(gè)Section指定名稱,也可以用其缺省的索引,從上到下依次為1、2…。每個(gè)Section均有Height和Visible屬性,您可以在一定條件下使一個(gè)Section不可見(jiàn)。在Section中可以放置各種報(bào)表控件,其中RptLabel、RptImage、RptShape和RptLine可以放在任意的Section中,用于輸出各種文字、圖形及表格線;RptTextBox只能放在細(xì)節(jié)中,一般用于綁定輸出DataMemeber提供的數(shù)據(jù)字段;RptFunction只能被放置在分組注腳中,用于輸出使用各種內(nèi)置函數(shù)計(jì)算出的合計(jì)、最大值、最小值、平均值、記數(shù)等等。上述報(bào)表控件中常用公共屬性有用于控制位置及高度寬度的Top、Left、Height、Width和控制可見(jiàn)性的Visible;其中RptTextBox還有DataField、DataMember、DataFormat及Font屬性;其他屬性不再多說(shuō)。

  然后介紹一下我的使用經(jīng)驗(yàn)。一是對(duì)想控制的報(bào)表控件按類型有規(guī)律的命名;二是用RptShape的矩形框做表格線框,比用RptLine畫(huà)框省事多了,只有斜線才使用RptLine;三是報(bào)表標(biāo)題及報(bào)表中的表頭文字、日期及頁(yè)碼用RptLabel,其中Caption屬性支持轉(zhuǎn)義字符,%D為長(zhǎng)格式日期,%d為短格式日期,%P為總頁(yè)數(shù),%p為當(dāng)前頁(yè)碼;四是對(duì)固定報(bào)表在設(shè)計(jì)窗口直接將報(bào)表控件擺放到位,對(duì)于活報(bào)表,應(yīng)首先考慮報(bào)表最大的情形,將足夠的控件分別放置在不同區(qū)域,位置大小可以不必深究,然后在報(bào)表輸出前用VBA代碼對(duì)所有控件的屬性進(jìn)行調(diào)整,包括位置、高度、寬度、字體、對(duì)齊方式、顯示格式、可見(jiàn)性等等,相應(yīng)的對(duì)Section也應(yīng)根據(jù)情況調(diào)整其高度和可見(jiàn)性。


最后用一個(gè)實(shí)例模板來(lái)說(shuō)明其使用方法。

  連接數(shù)據(jù)庫(kù)


With 數(shù)據(jù)環(huán)境.rsCommand名
If .State = adStateOpen Then .Close
.Source = SQL語(yǔ)句
.Open 打開(kāi)想輸出的數(shù)據(jù)庫(kù)數(shù)據(jù)項(xiàng)以便輸出
End With
With 報(bào)表名
 .DataSource=數(shù)據(jù)環(huán)境
 .DataMember=Command名 這兩行也可固定設(shè)好而不必每次設(shè)置
 設(shè)置頁(yè)表頭部分(RpttLabel…為報(bào)表控件名)
 .Sections(2).Controls("RptLabelPage").Caption = "共%P頁(yè)第%p頁(yè)"
 .Sections(2).Controls("RptLabelDate").Caption = "打印日期:%D"
 .Sections(3).Controls("RptLabel1").Left=…
 …
 設(shè)置細(xì)節(jié)部分(RptShapeX、RptTextBoxX為報(bào)表控件名)
 .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").Visible=False
 .Sections(3).Controls("RptTextBoxN").Visible=False
 …
 . Sections(3).Height=計(jì)算出的或固定的細(xì)節(jié)高度
動(dòng)態(tài)調(diào)整報(bào)表標(biāo)題(RptLabelTitle為報(bào)表標(biāo)簽控件名)
 .Sections(2). Controls("RptLabelTitle").Left=…
 …
 .Sections(2). Controls("RptLabelTitle").Alignment=…
 …
 調(diào)整完畢后
 .Show 或 .PrintReport
End With



  這樣做的優(yōu)點(diǎn)是報(bào)表設(shè)計(jì)時(shí)簡(jiǎn)單,調(diào)整方便、隨意,只需更改一點(diǎn)代碼,而不必為了一點(diǎn)點(diǎn)的修改而費(fèi)神的在設(shè)計(jì)窗口調(diào)整半天。

溫馨提示:喜歡本站的話,請(qǐng)收藏一下本站!

本類教程下載

系統(tǒng)下載排行

主站蜘蛛池模板: 欧美亚洲日本国产 | 久久两性视频 | 国产99久久精品一区二区 | 欧美aaaaaaaaa| 亚洲热热久久九九精品 | 欧美啪啪精品 | 亚洲乱码一二三四区国产 | 91久久国产成人免费观看资源 | 桃色视频网站 | 国产精品久久久久久夜夜夜夜 | 婷婷综合久久中文字幕蜜桃三 | 久久99精品视免费看 | 亚洲欧美在线观看播放 | 综合网天天操天天射 | 色综合久久中文综合网 | 国产欧美亚洲精品一区 | 国产精品一区二区久久精品涩爱 | 国产在线不卡午夜精品2021 | 手机国产日韩高清免费看片 | 999这里只有精品 | 狠狠色狠狠色综合日日小蛇 | 在线成人免费 | 免费国产99久久久香蕉 | 在线青青| 香蕉在线精品一区二区 | 久久最近最新中文字幕大全 | 天天看天天射天天碰 | 成人综合婷婷国产精品久久免费 | 国产一区曰韩二区欧美三区 | 91丨九色丨对白 | 国产成人一区在线播放 | 日韩精品亚洲人成在线播放 | 亚洲乱码中文字幕综合 | 中文字幕一区二区三区久久网站 | 性欧美欧美之巨大69 | 欧美综合图区亚洲综合图区69 | 国产精品久久香蕉免费播放 | 久青草香蕉精品视频在线 | 视频在线观看免费网站 | 久久99热精品免费观看无卡顿 | 女网址www 女|