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

首頁 > 編程 > Delphi > 正文

Delphi+Word解決方案參考

2019-11-18 18:27:09
字體:
來源:轉載
供稿:網友
[轉]這是我做項目過程中自己做的幾個函數,見到大家都在問Word的問題?,F在拿出來和大家共享。(希望有朋友可以進一步添加新的功能,或者做成包或者lib等,更方便大家使用。我自己是沒有時間啦,呵呵)

使用前,先根據需要建立一個空的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.document..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;

            //設置單元格對齊方式

            if dbG.Columns[j-1].Alignment=taCenter then

              wTable.Cell(i+iTitleLine,k).Range.ParagraphFormat.Alignment:=wdAlignParagraphCenter

            else if dbG.Columns[j-1].Alignment=taRightJustify then

              wTable.Cell(i+iTitleLine,k).Range.ParagraphFormat.Alignment:=wdAlignParagraphRight

            else if dbG.Columns[j-1].Alignment=taLeftJustify then

              wTable.Cell(i+iTitleLine,k).Range.ParagraphFormat.Alignment:=wdAlignParagraphJustify;

            k:=k+1;

          end;

        end;

        dbG.DataSource.DataSet.Next;

      end;

    end;

    //結尾行

    for i:=1 to dbG.FooterRowCount Do

    begin

      k:=1;

      for j:=1 to dbG.Columns.Count Do

      begin

        if dbG.Columns[j-1].Visible then

        begin

          wTable.Cell(iLine+1+i,k).Range.InsertAfter(dbG.GetFootervalue(i-1,dbG.Columns[j-1]));

          //設置單元格對齊方式

          if dbG.Columns[j-1].Footer.Alignment=taCenter then

            wTable.Cell(iLine+1+i,k).Range.ParagraphFormat.Alignment:=wdAlignParagraphCenter

          else if dbG.Columns[j-1].Footer.Alignment=taRightJustify then

            wTable.Cell(iLine+1+i,k).Range.ParagraphFormat.Alignment:=wdAlignParagraphRight

          else if dbG.Columns[j-1].Footer.Alignment=taLeftJustify then

            wTable.Cell(iLine+1+i,k).Range.ParagraphFormat.Alignment:=wdAlignParagraphJustify;

          k:=k+1;

        end;

      end;

    end;

    //處理多行標題

    if dbG.UseMultiTitle then

    begin

      //先分割單元格,再逐個填入第二行

      k:=1;

      titleCol:=1;

      lastTitleSplit:=1;

      SubTitle:=0;

      lastTitle:='';

      for j:=1 to dbG.Columns.Count Do

      begin

        if dbG.Columns[j-1].Visible then

        begin

          titleList:=strSplit(dbG.Columns[j-1].Title.Caption,'|');

          if titleList.Count>1 then

          begin

            //處理第二行以上的內容

            wTable.Cell(1,k-SubTitle).Range.Cells.Split(titleList.Count,1,false);

            for titleSplit:=1 to titleList.Count-1 Do

            begin

              wTable.Cell(titleSplit+1,titleCol).Range.InsertAfter(titleList.Strings[titleSplit]);

            end;

            titleCol:=titleCol+1;

            //處理第一行合并

            if (lastTitleSplit=titleList.Count) and (lastTitle=titleList.Strings[0]) then

            begin

              //內容相同時,合并單元格

              wTable.Cell(1,k-SubTitle).Range.Copy;

              wRange:=wDoc.Range(wTable.Cell(1,k-SubTitle-1).Range.Start,wTable.Cell(1,k-SubTitle).Range.End);

              wRange.Cells.Merge;

              wRange.Paste;

              SubTitle:=SubTitle+1;

            end;

          end;

          lastTitle:=titleList.Strings[0];

          lastTitleSplit:=titleList.Count;

          titleList.Clear;titleList.Free;

          k:=k+1;

        end;

      end;

    end;

    //自動調整表格

    wTable.AutoFitBehavior(1);//根據內容自動調整表格wdAutoFitContent

    wTable.AutoFitBehavior(2);//根據窗口自動調整表格wdAutoFitWindow

    result:=true;

  except

    result:=false;

  end;

  try

    dbG.DataSource.dataset.EnableControls;

  except

  end;

end;

 

{

功能:在Word文件中插入文本(能夠自動進行換行處理)

lineText:要插入的文本

bNewLine:true時新起一行,false時在當前行插入

}

function PrnWordInsert(lineText:String;bNewLine:boolean=true):boolean;

var i:Integer;

begin

  try

    if bNewLine then

      wDoc.Range.InsertAfter(#13);

    //自動分行

    reWord.Lines.Clear;

    reWord.Lines.Add(lineText);

    //開始逐行插入

    for i:=0 to reWord.Lines.Count-1 Do

    begin

      //插入當前行

      wDoc.Range.InsertAfter(reWord.Lines[i]);

      //除最后一行外,自動加入新行

      if i<reWord.Lines.Count-1 then

        wDoc.Range.InsertAfter(#13);

    end;

    result:=true;

  except

    result:=false;

  end;

end;

 

{

功能:在Word文件的sBookMark書簽處插入TImage控件包含的圖片

}

function PrnWordInsert(var imgInsert:TImage;sBookMark:String=''):boolean;

var wRange:Variant;iRangeEnd:Integer;

begin

  try

    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;

    if imgInsert.Picture.Graphic<>nil then

    begin

      Cl
    exit;

  end;

  //目標文件去掉只讀屬性

  FileSetAttr(destFile,FileGetAttr(destFile) and not $00000001);

  result:=true;

end;

 

附:guiInfo源代碼

 

{

功能:封裝了各種性質的提示框

sMsg:要提示的消息

}

procedure guiInfo(sMsg:String);

begin

  MessageDlg(sMsg,mtInformation,[mbOK],0);

end;


上一篇:Delphi開發單機瘦數據庫程序要點

下一篇:Delphi開發國際化應用程序

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

新聞熱點

疑難解答

圖片精選

網友關注

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美精品国产精品日韩精品| 国产精品激情av在线播放| 亚洲国产精品人久久电影| 亚洲欧美国产精品| 亚洲一区二区三区乱码aⅴ蜜桃女| 国产欧美一区二区三区四区| 亚洲综合精品一区二区| 国产91精品高潮白浆喷水| 亚洲区中文字幕| 久久精品国产免费观看| 国产黑人绿帽在线第一区| 欧美肥老太性生活视频| 国产精品88a∨| 黄色精品在线看| 色久欧美在线视频观看| 国产日韩精品入口| 国产精品视频成人| 国产精品av在线| 欧美—级a级欧美特级ar全黄| 亚洲女人被黑人巨大进入| 亚洲性生活视频在线观看| 中文字幕日韩av电影| 亚洲欧美综合v| 精品偷拍一区二区三区在线看| 亚洲自拍在线观看| 国产精品成人av性教育| 色樱桃影院亚洲精品影院| 欧美成人午夜免费视在线看片| 国产欧美日韩亚洲精品| 欧美日韩国产一区二区三区| 亚洲护士老师的毛茸茸最新章节| 伦理中文字幕亚洲| 亚洲欧美日韩视频一区| 日韩在线高清视频| 精品中文字幕视频| 日本精品va在线观看| 亚洲国产精品小视频| 欧美精品videofree1080p| 国产精品丝袜高跟| 欧美高清在线播放| 日韩av免费在线| 国产一区二区三区日韩欧美| 日韩av三级在线观看| 久久全国免费视频| 国产极品精品在线观看| 成人在线视频网| 狠狠操狠狠色综合网| 中文字幕视频在线免费欧美日韩综合在线看| 国产精品av电影| 日本国产欧美一区二区三区| 亚洲欧美国产另类| 欧美成人免费va影院高清| 欧美精品情趣视频| 尤物九九久久国产精品的特点| 国产精品久久久av| 亚洲**2019国产| 国产精品美女主播在线观看纯欲| 欧美日韩国产在线看| 欧美精品www在线观看| 久久久在线观看| 欧美丰满片xxx777| 一区二区三区视频免费| 日韩av影视在线| 国产一区二区三区日韩欧美| 日韩在线播放av| 日韩久久免费视频| 色多多国产成人永久免费网站| 久久99热这里只有精品国产| 97久久精品在线| 国产日韩欧美黄色| 日韩精品免费一线在线观看| 在线观看欧美日韩国产| 久久精品视频中文字幕| 中文字幕日韩av综合精品| 日本高清视频精品| 国产福利精品视频| 久热精品视频在线免费观看| 国产精品久久久久福利| 久久久免费观看| 欧美黄色性视频| 亚洲精品中文字幕有码专区| 另类美女黄大片| 一本色道久久88综合日韩精品| 亚洲加勒比久久88色综合| 欧美精品久久久久久久久| 国产精品免费久久久久影院| 亚洲精品91美女久久久久久久| 国产精品夜间视频香蕉| 青青草原成人在线视频| 夜色77av精品影院| 成人午夜两性视频| 精品国产91久久久久久老师| 日韩国产高清污视频在线观看| 日韩高清电影免费观看完整版| 91精品国产网站| 中文字幕亚洲色图| 中文字幕9999| 97婷婷大伊香蕉精品视频| 欧美一级电影免费在线观看| 亚洲一区二区黄| 性欧美办公室18xxxxhd| 国产又爽又黄的激情精品视频| 成人免费视频网址| 国产精品一区二区三区免费视频| 精品亚洲一区二区三区在线播放| 成人黄色片网站| 精品国产31久久久久久| 久操成人在线视频| 亚洲综合自拍一区| 日韩美女在线播放| 欧美麻豆久久久久久中文| 久久艳片www.17c.com| 成人欧美一区二区三区在线湿哒哒| 大荫蒂欧美视频另类xxxx| 国产精品91在线| 亚洲性视频网站| 久久人人爽人人爽人人片亚洲| 亚洲a成v人在线观看| 亚洲成人三级在线| 亚洲激情国产精品| 欧美性xxxx极品hd满灌| 亚洲精品久久久久久下一站| 欧美国产日韩一区二区在线观看| 国产亚洲精品美女久久久| 26uuu国产精品视频| 色偷偷91综合久久噜噜| 中国日韩欧美久久久久久久久| 欧美精品一区在线播放| 久久精品久久久久| 一区二区三区视频免费在线观看| 久久久久久久久久久久久久久久久久av| 一个人www欧美| 国产精品av在线播放| 久久久久久久久久久国产| 一本久久综合亚洲鲁鲁| 日韩视频在线观看免费| 亚洲欧洲在线免费| 国产精品久久久久久一区二区| 欧美在线视频网站| 亚洲国产精品成人一区二区| 97精品国产97久久久久久春色| 91精品视频一区| 亚洲美女性生活视频| 欧美精品亚州精品| 国产成人综合av| 在线一区二区日韩| 日韩国产欧美精品在线| 久久91亚洲精品中文字幕| 日韩人在线观看| 国产视频一区在线| 国产精品99一区| 性欧美xxxx视频在线观看| 精品久久香蕉国产线看观看亚洲| 国产精品免费视频xxxx| 黄色91在线观看| 亚洲精品美女视频| 国产福利成人在线| 亚洲精品免费一区二区三区| 亚洲午夜女主播在线直播| 欧美性少妇18aaaa视频| 久久久久亚洲精品国产| 欧美日韩国产二区| 亚洲精品色婷婷福利天堂| 97精品一区二区视频在线观看|