• <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

        當前位置:雨林木風下載站 > 技術開發(fā)教程 > 詳細頁面

        VB6中用DataReport做報表

        VB6中用DataReport做報表

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

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

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

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

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


        最后用一個實例模板來說明其使用方法。

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


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



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

        溫馨提示:喜歡本站的話,請收藏一下本站!

        本類教程下載

        系統(tǒng)下載排行

        主站蜘蛛池模板: 一区二区三区免费电影| 在线观看肉片AV网站免费 | 免费国产a理论片| 日本高清免费网站| 亚洲AV噜噜一区二区三区| 成人毛片免费视频| 国产精品无码亚洲精品2021| 日本v片免费一区二区三区 | 亚洲午夜国产精品无卡| 91久久精品国产免费直播| 亚洲人成777在线播放| 国产h视频在线观看免费| 中文字幕精品三区无码亚洲| 免费特级黄毛片在线成人观看| 亚洲精品天堂无码中文字幕| 国产乱人免费视频| www在线观看免费视频| 久久青青成人亚洲精品| 亚洲人成色在线观看| 亚洲精品无码专区2| 久草福利资源网站免费| 亚洲卡一卡2卡三卡4麻豆| 国产精品色午夜免费视频| 亚洲免费视频一区二区三区| 亚洲电影中文字幕| 国产免费人成视频尤勿视频| 久久精品国产亚洲av麻| 在线观看免费亚洲| 久操视频免费观看| 亚洲欧美日韩久久精品| 国产AV无码专区亚洲AV漫画| 18禁美女裸体免费网站| 国产精品亚洲精品爽爽| 日本亚洲成高清一区二区三区| 牛牛在线精品观看免费正| 亚洲成色在线影院| 国产美女做a免费视频软件| 国产精品免费福利久久| 久久久久久亚洲精品无码| 久久久久亚洲精品影视| 午夜爱爱免费视频|