国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > 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的新特性[翻譯]

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

新聞熱點

疑難解答

圖片精選

網友關注

主站蜘蛛池模板: 两当县| 绥芬河市| 丹阳市| 西城区| 隆回县| 新巴尔虎左旗| 垦利县| 石渠县| 观塘区| 唐山市| 曲麻莱县| 健康| 江北区| 浮梁县| 绩溪县| 张家口市| 泉州市| 新源县| 漯河市| 克什克腾旗| 本溪| 麻阳| 鲜城| 中卫市| 民丰县| 合水县| 芷江| 江口县| 稻城县| 龙海市| 万全县| 房产| 克拉玛依市| 安国市| 凌海市| 林甸县| 东城区| 兴国县| 柘荣县| 宜春市| 景谷|