a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > Delphi > 正文

用Word做Delphi報表輸出工具

2019-11-18 18:54:15
字體:
來源:轉載
供稿:網友
筆者在實際應用中發現,報表的內容一般很少變動,但其字體格式及版式是經常變動的,而且有時用戶為了某種需要,不想修改數據庫的真實內容而又要改變報表內容。如果用ReportSmith可以解決前者問題,但對于后者則無能為力了,且其界面是英文的,不合用戶習慣。如果用3.0中的TQReport的報表部件,則兩者都不能實時解決,必須修改原代碼后重新編譯才能使用。而使用WordExcel則完全可以克服以上不足。具體實現如下(以Word實現為例):

  首先用Word編輯報表格式,并排好版,把將要輸出的數據項用表單域代替,并取名。這里我們暫時假設有表單域Item1及Item2(均為文本型),將這個文檔存為模板文件Example.dot,然后按如下步驟進行:

  1)運行Delphi3,在Form1里加入一個System部件集里的TDdeClientCov部件,取名為DdeExample,將其ConnectMode設為ddeManual(手動方式);將DdeService設為‘(WinWord)’;將Serviceapplication設為‘WinWord’。

  2)編寫一個自定義過程,以激活Word,如下:
  PRocedure Tform1.WordActive(Cmds: TStrings);
  var
     WordPath: String;
  begin
     if(not DdeExample.OpenLink) then {判斷是否巳動態鏈接}
     begin
       if(FindWindow('OpusApp', nil)=0) then
       begin
          WordPath := 'C:msofficewinword';
          if(WordPath=') then
             ShowMessage('中文Word未安裝或未設置路徑,請安裝設置Word中文 版。')
          else begin
             DdeExample.ServiceApplication := WordPath+'Winword.exe';
             if(DdeExample.OpenLink) then {如果巳動態鏈接執行宏命令}            
                  DdeExample.ExecuteMacroLines(Cmds,False)
              else
                  ShowMessage('無法啟動Word中文版!');
               DdeExample.ServiceApplication := 'WinWord.exe';
           end;
      end
      else begin{如果巳動態鏈接執行宏命令}
         DdeExample.ExecuteMacroLines(Cmds,False);
      end;
    end
    else
      DdeExample.ExecuteMacroLines(Cmds,false);
  end;

  在private聲明區里加入如下:
  procedure ActiveWord(Cmds: TStrings);

  3)在Form1中加入一個按鈕Button1,在其onclick事件里寫如下代碼:
  procedure TForm1.Button1Click(Sender: TObject);
  var
     Cmds:TStringList;{創建Cmds}
     TempItem1,TempItem2:String;
  begin
     cmds:=TStringList.Create;
     cmds.Clear;
     TempItem1:='數據項一';
     TempItem2:='數據項二';
     with Cmds do
     begin
        Clear;
        Add('[FileNew.Template ="Example.Dot″]');{打開模板文件Example.Dot}
        Add('[AppMaximize]');{文檔最大化}
        Add('[SetFormResult"Item1″,″'+TempItem1+'″]');{將數據TempItem1傳給表單域Item1}
        Add('[SetFormResult"Item2″,″'+TempItem2+'″]);{將數據TempItem2傳給表單域Item2}
     end;
     WordActive(DdeExample,Cmds);{調用自定義過程}
     Cmds.Free;{釋放Cmds}
  end;

  運行這個程序,單擊Button1,大家可以發現Word被啟動了,屏幕上出現了:數據項一;數據項二兩個數據項。最后,大家可以任意修改本報表的格式及數據,因為這時這個報表與具體的應用程序巳沒有關系了。

  本例中用的是中文Word6或中文Word7。由于Word97的宏命令巳變為Visual Basic語句,如大家想用Word97實現,請將其宏命令改變為相應的代碼。

  這是個簡單的示例,大家可以利用Word的宏錄制功能,錄取更多的宏(如自動生成表格、填充文字、變動字體等宏命令),并與數據庫的各種表聯系起來,依次加入Cmds中即可實現您所要求的更復雜的功能。


上一篇:在DELPHI程序中使用ADO對象存取ODBC數據庫

下一篇:Delphi6的新特性[翻譯]

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網友關注

主站蜘蛛池模板: 成人免费高清视频 | 国外成人在线视频网站 | 国产在线啪 | 精品一区二区三区免费 | 中文字幕一区二区三区四区五区 | 成年免费视频 | 亚洲综合色视频在线观看 | 一级爱爱片 | 人妖 丝袜 另类 亚洲 | 日韩高清中文字幕 | 久久久久久亚洲精品中文字幕 | 欧美日韩一区二区三区在线观看 | 欧美性猛交久久久乱大交小说 | 狠狠艹| 亚洲精品v | 久草视频网址 | 国产精品日韩欧美一区二区 | 国产在线精品一区二区 | 国产久精品 | 精品久久久久久 | 国产羞羞视频在线观看 | 国产精品久久久久久妇女6080 | 精品久久一区二区三区 | 国产视频福利在线观看 | 中文字幕在线免费视频 | 99国产精品 | 欧美日韩精品一区二区三区 | 91久久久精品视频 | 亚洲精品乱码久久久久久蜜桃图片 | 国产成人精品毛片 | 国产乱码精品一区二区三区忘忧草 | 人人超碰在线观看 | 欧美一级淫片免费看 | 国产国拍亚洲精品av | 无码一区二区三区视频 | 凹凸日日摸日日碰夜夜爽孕妇 | 欧美成人一区二区三区片免费 | 欧洲一级黄 | 亚洲精品乱码久久久久久蜜桃不卡 | av网站在线免费看 | 久久久久亚洲 |