Solved

Creating good-looking Word files

Posted on 2004-04-15
6
1,256 Views
Last Modified: 2011-09-20
Hello!
  I need to create good-looking Doc files for my current project.
  I may need things like creating tables in the file, insert images, draw shapes etc.
  So, basically I need a list of commands I can use with OLE automation, and also some sample code (I haven't created word files using Delphi before).
  Looking forward to your help.
Thanks,
...Shu
0
Comment
Question by:snehanshu
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
  • 3
6 Comments
 
LVL 5

Author Comment

by:snehanshu
ID: 10839883
Wow!
I got a sample fine now, and I would need the following:
* Writing in headers/footers of the word document
* Bulleting, tabs etc.
* Text boxes (and text inside them), other shapes (lines, circle)
* Tables (and formatting the table like background of first row, changing color of some cell etc.)
* Inserting images in the document as well as the header/footer
* Other goodies you can suggest

Please help!
Thanks,
...Shu
0
 
LVL 2

Expert Comment

by:ferhad
ID: 10840234
You can find the list of commands from vbawd10.chm file located in your system. Its located in the following path:
C:\Program Files\Microsoft Office\Office10\1049
I will send you working examples too.
Regards Ferhad
0
 
LVL 5

Author Comment

by:snehanshu
ID: 10840280
Thanks ferhad!
Working samples of each of the things in my wish-list above would be a just what I need.
...Shu
0
Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 2

Accepted Solution

by:
ferhad earned 250 total points
ID: 10840476
The following code opens an existing *.doc file, creates table and inserts data into this table. Create *.doc file and call it Doc1. Wait new codes from me. They will come soon. :)

var pmainDir: string;
const wdLine = $00000005;
      FILE_REPORT = 'Doc1.doc';

pMainDir := ExtractFilePath(Application.ExeName);
wrdApp := CreateOleObject('Word.Application');
wrdApp.Application.Visible := True;
wrdApp.Application.WindowState := wdWindowStateMinimize;
wrdApp.Documents.Add(Template := pMainDir + FILE_REPORT);
wrdApp.Selection.Font.Bold := True;
wrdApp.Selection.Font.Size := 8;
wrdApp.Selection.Font.Name := 'Verdana Azeri Lat';

wrdApp.ActiveDocument.Tables.Add(wrdApp.Selection.Range, NumRows := 20, NumColumns :=8);
wrdApp.Selection.TypeText(Text := 'Name');
wrdApp.Selection.MoveRight(Count := 1);
wrdApp.Selection.TypeText(Text := 'Surname');
wrdApp.Selection.MoveRight(Count := 1);
wrdApp.Selection.TypeText(Text := 'Phone');
wrdApp.Selection.MoveRight(Count := 1);
wrdApp.Selection.TypeText(Text := 'Address');
wrdApp.Selection.MoveRight(Count := 1);
wrdApp.Selection.TypeText(Text := 'Mobil');
wrdApp.Selection.MoveRight(Count := 1);
wrdApp.Selection.TypeText(Text := 'Country');
wrdApp.Selection.MoveRight(Count := 1);
wrdApp.Selection.TypeText(Text := 'City');
wrdApp.Selection.MoveRight(Count := 1);
wrdApp.Selection.TypeText(Text := 'Zip Postal Code');
wrdApp.Selection.MoveDown(Unit := wdLine, Count := 1);
wrdApp.Selection.MoveLeft(Count := 8);
0
 
LVL 2

Expert Comment

by:ferhad
ID: 10840504
Add into uses list ComObj.
And one important thing type of the variable wrdApp is "Variant".
0
 
LVL 5

Author Comment

by:snehanshu
ID: 10841534
ferhad,
I am leaving for the day: will be only able to check things on Monday now.
Looking forward to more examples!
Thanks,
...Shu


P.S.
  Here's what I did so far: (Write to header and create a table)

procedure TAutoDocFOrm.FlNmBtnClick(Sender: TObject);
const
  Line1 = 'January,February,March';
  Line2 = '31,28,31';
  Line3 = '31,59,90';
var
  r,s,
  Direction, Separator, Format: OleVariant;

  Word, rng, Sec, Sel, HdrTyp, hdr: Variant;
  SaveChanges, MyFlNm: OleVariant;
  MyRange: Range;
begin
  If FileExists(FlNmBox.Text) then
    SaveFlNmDlg.FileName := FlNmBox.Text
  Else
  If DirectoryExists(FlNmBox.Text) then
    SaveFlNmDlg.InitialDir := FlNmBox.Text;
  If SaveFlNmDlg.Execute Then
  Begin

    MyFlNm := SaveFlNmDlg.FileName;

    Word := CreateOleObject('Word.Application');
    Word.Application.Visible := True;

    Word.Documents.Add(EmptyParam, EmptyParam, EmptyParam, EmptyParam);
    S := Word.Selection;
    R := S.Range;

    Sec := Word.Application.ActiveDocument.Sections.Item(1);
    HdrTyp := wdHeaderFooterPrimary;
    Hdr := sec.Headers.Item(HdrTyp);
    rng := Hdr.Range;

    rng.Select;
    Word.Selection.TypeText( text := ' Snehanshu. Page ');
    Word.Selection.Fields.Add(Range:= Word.Selection.Range , Type:=wdFieldPage);
    Word.Selection.TypeText( text := ' of ');
    Word.Selection.Fields.Add(Range:= Word.Selection.Range, Type:=wdFieldNumPages);
    R.Select;
    Direction := wdCollapseEnd;
    R.Collapse(Direction);
    R.InsertAfter(Line1);
    R.InsertParagraphAfter;
    R.InsertAfter(Line2);
    R.InsertParagraphAfter;
    R.InsertAfter(Line3);
    R.InsertParagraphAfter;
    Separator := ',';
    Format := wdTableFormatGrid1;
    R.ConvertToTable(Separator, EmptyParam, EmptyParam,
                     EmptyParam, Format, EmptyParam,
                     EmptyParam, EmptyParam, EmptyParam,
                     EmptyParam, EmptyParam, EmptyParam,
                     EmptyParam, EmptyParam);
    R.Tables.Item(1).Rows.Item(1).Shading.Texture := wdTexture5Percent;



    Word.ActiveDocument.SaveAs(MyFlNm, EmptyParam, EmptyParam , EmptyParam, EmptyParam,
    EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam);

    SaveChanges := wdPromptToSaveChanges;
    Word.Quit(SaveChanges, EmptyParam, EmptyParam);



  End;


end;
0

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction The parallel port is a very commonly known port, it was widely used to connect a printer to the PC, if you look at the back of your computer, for those who don't have newer computers, there will be a port with 25 pins and a small print…
In my programming career I have only very rarely run into situations where operator overloading would be of any use in my work.  Normally those situations involved math with either overly large numbers (hundreds of thousands of digits or accuracy re…
A short tutorial showing how to set up an email signature in Outlook on the Web (previously known as OWA). For free email signatures designs, visit https://www.mail-signatures.com/articles/signature-templates/?sts=6651 If you want to manage em…
Finds all prime numbers in a range requested and places them in a public primes() array. I've demostrated a template size of 30 (2 * 3 * 5) but larger templates can be built such 210  (2 * 3 * 5 * 7) or 2310  (2 * 3 * 5 * 7 * 11). The larger templa…

730 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question