亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Delphi > 正文

Delphi+Word解決方案參考

2019-11-18 18:29:50
字體:
來源:轉載
供稿:網友
DelphiWord解決方案參考
這是我做項目過程中自己做的幾個函數,見到大家都在問Word的問題。現在拿出來和大家共享。(希望有朋友可以進一步添加新的功能,或者做成包或者lib等,更方便大家使用。我自己是沒有時間啦,呵呵)
使用前,先根據需要建立一個空的WORD文件作為模板,在模板文件中設置好各種格式和文本。另外,其中的PRnWordTable的參數是TDBGridEh類型的控件,取自Ehlib2.6
其中用到的shFileCopy函數(用于復制文件)和guiInfo函數(用于顯示消息框)也是自己編寫的,代碼也附后。
示范代碼如下:
 
代碼完成的功能:
1.         替換打印模板中的“#TITLE#”文本為“示范代碼1”
2.         并且將DBGridEh1控件當前顯示的內容插入到文檔的末尾
3.         在文檔末尾插入一個空行
4.         在文檔末尾插入新的一行文本
5.         將文檔中的空行去掉
 
  if PrnWordBegin('C:/打印模板.DOC','C:/目標文件1.DOC') then
  begin
    PrnWordReplace('#TITLE#','示范代碼1');
    PrnWordTable(DBGridEh1);
    PrnWordInsert('');
    PrnWordInsert('這是新的一行文本');
    PrnWordReplace('^p^p','^p',true);
    PrnWordSave;
  end;
 
源代碼如下:
 
//Word打?。暶鞑糠郑?/B>
 
    wDoc,wApp:Variant;
    function PrnWordBegin(tempDoc,docName:String):boolean;
    function PrnWordReplace(docText,newText:String;bSimpleReplace:boolean=false):boolean;
    function PrnWordInsert(lineText:String;bNewLine:boolean=true):boolean;overload;
    function PrnWordInsert(var imgInsert:TImage;sBookMark:String=''):boolean;overload;
    function PrnWordInsert(var chartInsert:TChart;sBookMark:String=''):boolean;overload;
    function PrnWordTable(var dbG:TDBGridEh;sBookMark:String=''):boolean;
    procedure PrnWordSave;
    procedure PrnWordEnd;
 
//Word打?。▽崿F部分)
 
{
功能:基于模板文件tempDoc新建目標文件docName并打開文件
}
function PrnWordBegin(tempDoc,docName:String):boolean;
begin
  result:=false;
  //復制模版
  if tempDoc<>'' then
    if not shFileCopy(tempDoc,docName) then exit;
  //連接Word
  try
    wApp:=CreateOleObject('Word.application');
  except
    guiInfo('請先安裝 Microsoft Word 。');
    exit;
  end;
  try
    //打開
    if tempDoc='' then
    begin
      //創建新文檔
      wDoc:=wApp.Document.Add;
      wDoc.SaveAs(docName);
    end else begin
      //打開模版
      wDoc:=wApp.Documents.Open(docName);
    end;
  except
    guiInfo('打開模版失敗,請檢查模版是否正確。');
    wApp.Quit;
    exit;
  end;
  wApp.Visible:=true;
  result:=true;
end;
 
{
功能:使用newText替換docText內容
bSimpleReplace:true時僅做簡單的替換,false時對新文本進行換行處理
}
function PrnWordReplace(docText,newText:String;bSimpleReplace:boolean=false):boolean;
var i:Integer;
begin
  if bSimpleReplace then
  begin
    //簡單處理,直接執行替換操作
  try
    wApp.Selection.Find.ClearFormatting;
    wApp.Selection.Find.Replacement.ClearFormatting;
    wApp.Selection.Find.Text := docText;
    wApp.Selection.Find.Replacement.Text :=newText;
    wApp.Selection.Find.Forward := True;
    wApp.Selection.Find.Wrap := wdFindContinue;
    wApp.Selection.Find.Format := False;
    wApp.Selection.Find.MatchCase := False;
    wApp.Selection.Find.MatchWholeWord := true;
    wApp.Selection.Find.MatchByte := True;
    wApp.Selection.Find.MatchWildcards := False;
    wApp.Selection.Find.MatchSoundsLike := False;
    wApp.Selection.Find.MatchAllWordForms := False;
    wApp.Selection.Find.Execute(Replace:=wdReplaceAll);
    result:=true;
  except
    result:=false;
  end;
    exit;
  end;
  //自動分行
  reWord.Lines.Clear;
  reWord.Lines.Add(newText);
  try
    //定位到要替換的位置的后面
    wApp.Selection.Find.ClearFormatting;
    wApp.Selection.Find.Text := docText;
    wApp.Selection.Find.Replacement.Text := '';
    wApp.Selection.Find.Forward := True;
    wApp.Selection.Find.Wrap := wdFindContinue;
    wApp.Selection.Find.Format := False;
    wApp.Selection.Find.MatchCase := False;
    wApp.Selection.Find.MatchWholeWord := False;
    wApp.Selection.Find.MatchByte := True;
    wApp.Selection.Find.MatchWildcards := False;
    wApp.Selection.Find.MatchSoundsLike := False;
    wApp.Selection.Find.MatchAllWordForms := False;
    wApp.Selection.Find.Execute;
    wApp.Selection.MoveRight(wdCharacter,1);
    //開始逐行插入
    for i:=0 to reWord.Lines.Count-1 Do
    begin
      //插入當前行
      wApp.Selection.InsertAfter(reWord.Lines[i]);
      //除最后一行外,自動加入新行
      if i<reWord.Lines.Count-1 then
        wApp.Selection.InsertAfter(#13);
    end;
    //刪除替換位標
    wApp.Selection.Find.ClearFormatting;
    wApp.Selection.Find.Replacement.ClearFormatting;
    wApp.Selection.Find.Text := docText;
    wApp.Selection.Find.Replacement.Text := '';
    wApp.Selection.Find.Forward := True;
    wApp.Selection.Find.Wrap := wdFindContinue;
    wApp.Selection.Find.Format := False;
    wApp.Selection.Find.MatchCase := False;
    wApp.Selection.Find.MatchWholeWord := true;
    wApp.Selection.Find.MatchByte := True;
    wApp.Selection.Find.MatchWildcards := False;
    wApp.Selection.Find.MatchSoundsLike := False;
    wApp.Selection.Find.MatchAllWordForms := False;
    wApp.Selection.Find.Execute(Replace:=wdReplaceAll);
    result:=true;
  except
    result:=false;
  end;
end;
 
{
功能:打印TDBGridEh當前顯示的內容
基于TDBGridEh控件的格式和內容,自動在文檔中的sBookMark書簽處生成Word表格
目前能夠支持單元格對齊、多行標題(兩行)、底部合計等特性
sBookMark:Word中要插入表格的書簽名稱
}
function PrnWordTable(var dbG:TDBGridEh;sBookMark:String=''):boolean;
var iCol,iLine,i,j,k:Integer;
    wTable,wRange:Variant;
    iRangeEnd:longint;
    iGridLine,iTitleLine:Integer;
    getTextText:String;getTextDisplay:boolean;
    titleList:TStringList;titleSplit,titleCol:Integer;lastTitleSplit,SubTitle:Integer;lastTitle:String;
begin
  result:=false;
  try
    //計算表格的列數(不包括隱藏的列)
    iTitleLine:=1;  //始終默認為1
    iCol:=0;
    for i:=0 to dbG.Columns.Count-1 Do
    begin
      if dbG.Columns[i].Visible then
      begin
        iCol:=iCol+1;
      end;
    end;
    //計算表格的行數(不包括隱藏的列)
    if dbG.DataSource.DataSet.Active then
      iLine:=dbG.DataSource.DataSet.RecordCount
    else
      iLine:=0;
    iGridLine:=iLine+iTitleLine+dbG.FooterRowCount;
    //定位插入點
    if sBookMark='' then
    begin
      //在文檔末尾
      iRangeEnd:=wDoc.Range.End-1;
      if iRangeEnd<0 then iRangeEnd:=0;
      wRange:=wDoc.Range(iRangeEnd,iRangeEnd);
    end else begin
      //在書簽處
      wRange:=wDoc.Range.Goto(wdGoToBookmark,,,sBookMark);
    end;
    wTable:=wDoc.Tables.Add(wRange,iGridLine,iCol);
    wTable.Columns.AutoFit;
    //標題行
    k:=1;
    for j:=1 to dbG.Columns.Count Do
    begin
      if dbG.Columns[j-1].Visible then
      begin
        if dbG.UseMultiTitle then
        begin
          titleList:=strSplit(dbG.Columns[j-1].Title.Caption,'|');
          wTable.Cell(1,k).Range.InsertAfter(titleList.Strings[0]);
        end else
          wTable.Cell(1,k).Range.InsertAfter(dbG.Columns[j-1].Title.Caption);
        //設置單元格對齊方式
        if dbG.Columns[j-1].Title.Alignment=taCenter then
          wTable.Cell(1,k).Range.ParagraphFormat.Alignment:=wdAlignParagraphCenter
        else if dbG.Columns[j-1].Title.Alignment=taRightJustify then
          wTable.Cell(1,k).Range.ParagraphFormat.Alignment:=wdAlignParagraphRight
        else if dbG.Columns[j-1].Title.Alignment=taLeftJustify then
          wTable.Cell(1,k).Range.ParagraphFormat.Alignment:=wdAlignParagraphJustify;
        k:=k+1;
      end;
    end;
    //填寫每一行
    if iLine>0 then
    begin
      dbG.DataSource.dataset.DisableControls;
      dbG.DataSource.DataSet.First;
      for i:=1 to iLine Do
      begin
        k:=1;
        for j:=1 to dbG.Columns.Count Do
        begin
          if dbG.Columns[j-1].Visible then
          begin
            if dbG.Columns[j-1].FieldName<>'' then //避免由于空列而出錯
            begin
              //如果該列有自己的格式化顯示函數,則調用顯示函數獲取顯示串
              getTextText:='';
              if Assigned(dbG.DataSource.DataSet.FieldByName(dbG.Columns[j-1].FieldName).OnGetText) then
              begin
                dbG.DataSource.DataSet.FieldByName(dbG.Columns[j-1].FieldName).OnGetText(dbG.DataSource.DataSet.FieldByName(dbG.Columns[j-1].FieldName),getTextText,getTextDisplay);
                wTable.Cell(i+iTitleLine,k).Range.InsertAfter(getTextText);
              end else begin
                //使用數據庫內容顯示
                wTable.Cell(i+iTitleLine,k).Range.InsertAfter(dbG.DataSource.DataSet.FieldByName(dbG.Columns[j-1].FieldName).AsString);
              end;
            end;

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91av在线免费观看视频| 亚洲理论在线a中文字幕| 欧美视频免费在线| 欧美精品久久久久| 欧美精品久久久久久久| 欧美激情一二区| 亚洲九九九在线观看| 欧美人与物videos| 成人黄色在线观看| 亚洲天堂成人在线视频| 欧美成人精品在线观看| 国产欧美精品日韩精品| 91久久精品国产91久久| 国产精品嫩草影院一区二区| 亚洲第一视频网站| 久久艹在线视频| 欧美日韩一二三四五区| 欧美电影免费观看高清完整| 9.1国产丝袜在线观看| 91成人天堂久久成人| 亚洲第一视频网| 欧美—级高清免费播放| 国产精品爱啪在线线免费观看| 91香蕉嫩草神马影院在线观看| 国产精品免费看久久久香蕉| 国内精品久久久久| 一区二区欧美亚洲| 国产精品一香蕉国产线看观看| 欧美国产视频日韩| 日韩av手机在线看| 亚洲丁香久久久| 亚洲欧美激情一区| 亚洲级视频在线观看免费1级| 91免费欧美精品| 狠狠色狠色综合曰曰| 国产精自产拍久久久久久蜜| 亚洲精品一区久久久久久| 亚洲天堂av图片| 欧美激情一区二区三区在线视频观看| 国产精品久久久久99| 亚洲第一视频网站| 欧美高跟鞋交xxxxxhd| 欧美性生交大片免网| 国产精品爽爽爽爽爽爽在线观看| 欧美成人免费va影院高清| 亚洲欧美福利视频| 亚洲综合日韩中文字幕v在线| 亚洲欧美日韩久久久久久| 在线视频中文亚洲| 欧美极品少妇xxxxⅹ免费视频| 91手机视频在线观看| 欧美成人免费在线视频| 亚洲电影免费观看高清完整版| 久久久免费精品视频| 亚洲精品福利资源站| 一区二区三区视频免费| 欧美国产日韩xxxxx| 亚洲成av人片在线观看香蕉| 日本乱人伦a精品| 国产精品国产自产拍高清av水多| 一本大道久久加勒比香蕉| 亚洲人成伊人成综合网久久久| 91av视频导航| 日韩av综合中文字幕| 欧美不卡视频一区发布| 国产精品亚洲片夜色在线| 国产丝袜视频一区| 黑人精品xxx一区一二区| 中文字幕久精品免费视频| 青青草国产精品一区二区| 91日本在线观看| 正在播放国产一区| 久久精品人人做人人爽| 亚洲精品av在线| 日韩视频永久免费观看| 国产欧美日韩综合精品| 精品国产一区二区三区在线观看| 国产欧美韩国高清| 久久久av免费| 清纯唯美亚洲综合| 精品国内亚洲在观看18黄| 国产丝袜高跟一区| 亚洲国产精品成人av| 欧美午夜精品在线| 欧美视频在线观看免费| 九九久久精品一区| 欧美电影免费观看大全| 91久久久久久久久久久| 欧美国产日韩中文字幕在线| 欧美日韩国产一区二区| 欧美xxxx做受欧美.88| 欧美大尺度激情区在线播放| 国产成人精品久久| 国产xxx69麻豆国语对白| 精品动漫一区二区三区| 国产一区二区动漫| 在线观看免费高清视频97| 一区二区三区天堂av| 亚洲一区二区三区成人在线视频精品| 国产精品吊钟奶在线| 亚洲免费人成在线视频观看| 日韩中文字幕在线| 亚洲国产精品久久久| 国产欧美精品一区二区三区-老狼| 国产精品久久91| 成人黄色av网站| 国产视频亚洲精品| 亚洲男人第一av网站| 欧美日韩国产在线看| 亚洲免费福利视频| 国产福利精品视频| 欧美一级视频一区二区| 久久精品国产免费观看| 538国产精品一区二区在线| 久久视频在线免费观看| 欧美福利在线观看| 亚洲国产成人91精品| 91亚洲精品一区二区| 欧美理论在线观看| 欧美激情视频三区| 欧美大片第1页| 国产精品日韩在线一区| 精品久久久久国产| 亚洲a在线播放| 日韩av手机在线观看| 国产精品美乳在线观看| 欧美乱妇高清无乱码| 日韩麻豆第一页| 国产精品无码专区在线观看| 欧美日韩国产综合视频在线观看中文| 成人中心免费视频| 日韩电影在线观看中文字幕| 亚洲精品电影在线观看| 亚州欧美日韩中文视频| 国产亚洲精品美女| 国产精品日韩欧美大师| 亚洲欧美国内爽妇网| 在线精品国产欧美| 全球成人中文在线| 亚洲天堂av综合网| 国产精品极品美女粉嫩高清在线| 国产欧美在线视频| 亚洲精品久久久久| 九九热精品视频国产| 97超视频免费观看| 欧美重口另类videos人妖| 亚洲精品国产精品久久清纯直播| 亚洲天堂免费观看| 亚洲男人的天堂在线播放| 国产视频精品免费播放| 中文字幕亚洲一区在线观看| 日韩精品视频免费在线观看| 日韩va亚洲va欧洲va国产| 欧美激情一级欧美精品| 国产欧美日韩免费看aⅴ视频| 国产一区二区香蕉| 欧美黑人性生活视频| 亚洲人成绝费网站色www| 欧美成人网在线| 国产精品第8页| 国产精品免费久久久久久| 国产亚洲精品久久久久久牛牛| 国产精品a久久久久久| 欧美精品一区二区免费|