我使用以下代码使用Delphi XE5在MS Word中插入一个包含2个单元格的表。表格单元格的所有字体都非常简单。除了1个字。我需要这个词是大胆的,而其余的则不是。
请帮我调整我的代码,这样我就可以将1个单词加粗。
wrdDoc.Tables.Add(wrdSelection.Range,3,2);
wrdDoc.tables.Item(3).Rows.Alignment := wdAlignRowLeft;
wrdDoc.Tables.Item(3).Columns.Item(1).SetWidth(36,wdAdjustNone);
wrdDoc.Tables.Item(3).Columns.Item(2).SetWidth(379,wdAdjustNone);
wrdDoc.tables.Item(3).Borders.Item(wdBorderLeft).LineStyle := wdLineStyleNone;
wrdDoc.tables.Item(3).Borders.Item(wdBorderRight).LineStyle := wdLineStyleNone;
wrdDoc.tables.Item(3).Borders.Item(wdBorderVertical).LineStyle := wdLineStyleNone;
wrdDoc.tables.Item(3).Borders.Item(wdBorderTop).LineStyle := wdLineStyleNone;
wrdDoc.tables.Item(3).Borders.Item(wdBorderBottom).LineStyle := wdLineStyleNone;
wrdDoc.tables.Item(3).Borders.Item(wdBorderHorizontal).LineStyle := wdLineStyleNone;
wrdDoc.Tables.Item(3).Cell(1,1).Range.InsertAfter('8.1');
wrdDoc.Tables.Item(3).Cell(1,1).Range.Paragraphs.Alignment := wdAlignParagraphleft;
wrdDoc.Tables.Item(3).Cell(1,1).Range.Font.Size := 12;
wrdDoc.Tables.Item(3).Cell(1,1).Range.Font.Bold := false;
wrdDoc.Tables.Item(3).Cell(1,1).Range.Font.underline := false;
wrdDoc.Tables.Item(3).Cell(1,2).Range.InsertAfter('this will not be bold text');
wrdDoc.Tables.Item(3).Cell(1,2).Range.InsertAfter('this will not be bold text');
wrdDoc.Tables.Item(3).Cell(1,2).Range.InsertAfter('THIS TEXT MUST BE BOLD');
wrdDoc.Tables.Item(3).Cell(1,2).Range.Paragraphs.Alignment := wdAlignParagraphJustify;
wrdDoc.Tables.Item(3).Cell(1,2).Range.Font.Size := 12;
wrdDoc.Tables.Item(3).Cell(1,2).Range.Font.Bold := false;
wrdDoc.Tables.Item(3).Cell(1,2).Range.Font.underline := false;
正如您在代码的最后部分所看到的,InsertAfter()
有3个调用,我插入的句子非常长。而Delphi将我限制在255,所以我只是多次调用它们,它就像调用它一样好。
只有最后一次通话,必须是粗体。其余的应该保持上面定义的格式。
任何和所有帮助将不胜感激。谢谢
答案 0 :(得分:1)
我确实找到了办法。它有点乱,但能完成这项工作。
Procedure MakeBold(SearchStr:String);
Begin
WrdApp.Selection.Find.ClearFormatting;
WrdApp.Selection.Find.Text := SearchStr;
WrdApp.Selection.Find.Forward := True;
WrdApp.Selection.Find.Wrap := wdFindContinue;
WrdApp.Selection.Find.Format := False;
WrdApp.Selection.Find.MatchCase := true;
WrdApp.Selection.Find.MatchWholeWord := wrfMatchCase in Flags;
WrdApp.Selection.Find.MatchWildcards :=wrfMatchWildcards in Flags;
WrdApp.Selection.Find.MatchSoundsLike := False;
WrdApp.Selection.Find.MatchAllWordForms := False;
{ Perform the search }
WrdApp.Selection.Find.Execute();
WrdApp.Selection.Font.Bold:=True;
End;
然后我只需拨打MakeBold('THIS TEXT MUST BE BOLD');
即可解决问题。
仍然欢迎任何其他可能的答案,因为此方法可能会使其他不相关的文本也变粗。
答案 1 :(得分:0)
你工作太辛苦了。 :-)您需要更熟悉Word范围(以及临时变量的使用)。使用Word 2013在Delphi 10 Seattle中使用Word2010单元进行测试。
var
WordTbl: Table;
// Grab a local reference to the table for ease of use
Tbl := wrdDoc.Selection.Tables.Item(3);
Tbl.Cell(1, 2).Range.Text := 'not bold';
// Make sure the cell is the current selection
Tbl.Cell(1, 2).Select;
// Move the selection to the end of the text we wrote before
wrdDoc.Selection.EndKey(wdLine, wdMove);
// Add the next section of the text and move to the end, so we
// know for sure where Word thinks we are now. Notice the spaces
// at both ends - for some reason they make a difference
wrdDoc.Selection.Range.Text := ' BOLD TEXT ';
wrdDoc.Selection.EndKey(wdLine, wdMove);
// Move back two words to select the text we just added and bold
wrdDoc.Selection.MoveLeft(wdWord, 2, wdExtend);
wrdDoc.Selection.Font.Bold := 1;
// End of the line again, and turn bold off, then more text
wrdDoc.Selection.EndKey(wdLine, wdMove);
wrdDoc.Selection.Font.Bold := 0;
wrdDoc.Selection.Range.Text := 'not bold again';
答案 2 :(得分:0)
此解决方案使ActiveDocument中的所有匹配都为粗体
function TfmMain.MakeBold(SearchStr: String; App: OLEVariant {Word application var} ): Integer;
var
Find: OLEVariant;
begin
Find := App.Selection.Find;
Find.ClearFormatting;
Find.Forward := true;
Find.Wrap := wdFindStop;
Find.Format := false;
Find.MatchCase := false;
Find.MatchWholeWord := true;
Find.MatchWildcards := false;
Find.MatchSoundsLike := false;
Find.MatchAllWordForms := false;
Find.Text := SearchStr;
while Find.Execute() do
begin
App.Selection.Font.Bold := true;
App.Selection.Collapse(wdCollapseEnd);
end;
Find := UnAssigned;
end;