Solved

How to VBA add new text to a word table located in document header ?

Posted on 2013-11-29
8
4,005 Views
Last Modified: 2013-11-30
Dear Expert,

I have a word document contained two tables.

One table (Table 0) is located in the document header consists of two column and 3 rows, the number of rows and columns are FIXED.

Another table (Table 1) is located in the document body where data from Access recordsets will be filled via vba like code below:

Private Sub

    Dim db As DAO.Database
    Dim rs As DAO.Recordset
    Dim wd As Object
    Dim fld As Field
    Dim iRow As Integer
    Dim iCol As Integer
    Dim iTbl As Integer

    Set wd = CreateObject("Word.Application")
    Set mydoc = wd.Documents.Open("C:\Sample.doc")
    Set db = CurrentDb()
     
   
    ' ** Starts Filling In Field Data into Table 1 Located in Document Body **  

    Set rs = db.OpenRecordset("MyRecordSets")
             
    iTbl = 1      'Existing table number in Word document body
    iRow = 1    'Starting row in table
    wd.Visible = True
       
    Do Until rs.EOF
       
        If iRow > mydoc.tables(iTbl).Rows.Count Then
            mydoc.tables(iTbl).Rows.Add
        End If
       
        For Each fld In rs.Fields
            iCol = iCol + 1
            mydoc.tables(iTbl).Cell(iRow, iCol).Range.Text = Nz(fld.Value)
        Next
        rs.MoveNext
        iRow = iRow + 1
        iCol = 0
    Loop

   
    Set rs = Nothing
    Set mydoc = Nothing
    Set wd = Nothing
   

End Sub

My question is how do I programmatically add text to rows of Table 0 located in Document Header before the transfer of recordsets into Table 1?

Attached is the graphical explanation of the sample document, the gray lined table represent Table 0 located in document header.

Thanks in advance.
Example.JPG
0
Comment
Question by:kaysoo
  • 3
  • 3
  • 2
8 Comments
 
LVL 39

Expert Comment

by:als315
ID: 39685796
Can you upload your Word document?
0
 
LVL 76

Expert Comment

by:GrahamSkan
ID: 39685873
Here is some code to put some text in the table.
Dim tbl As Table

Set tbl = mydoc.Sections.First.Headers(wdHeaderFooterPrimary).Range.Tables(1)
tbl.Cell(1, 1).Range.Text = "Some text"
tbl.Cell(1, 2).Range.Text = "Some more text"

Open in new window

0
 

Author Comment

by:kaysoo
ID: 39686508
Thanks for reply.

GrahamSkan, I hv tried your codes but I received some errors, I execute the VB codes from a command button in Access 2003 form.

The error shown as attached file. I also upload the sample word document as reference.

Hope you guys can help.

Thanks
CompileError.JPG
FC0211sample.doc
0
 
LVL 39

Accepted Solution

by:
als315 earned 350 total points
ID: 39686547
You can use GrahamScan's code with small modifications:
   
Set tbl = mydoc.Sections.First.Headers(1).Range.Tables(1)
    tbl.Cell(1, 2).Range.Text = "String1"
    tbl.Cell(2, 2).Range.Text = "String2"
    tbl.Cell(3, 2).Range.Text = "String3"
    Set tbl = Nothing

Open in new window

0
Complete VMware vSphere® ESX(i) & Hyper-V Backup

Capture your entire system, including the host, with patented disk imaging integrated with VMware VADP / Microsoft VSS and RCT. RTOs is as low as 15 seconds with Acronis Active Restore™. You can enjoy unlimited P2V/V2V migrations from any source (even from a different hypervisor)

 
LVL 76

Assisted Solution

by:GrahamSkan
GrahamSkan earned 150 total points
ID: 39686555
You are getting a Run-time error '5941' : The requested member of the collection does not exist. It is on the 'Set tbl' line.

The code works for me with the document. that you posted

There is such a Section - all documents have a First Section. The Section does have a Primary Header. In the document that you posted there is a table in the header, so it is difficult to know why it doesn't work for you.

This version splits the line up so you can see which item from which collection can't be found.
Dim tbl As Table
Dim sec As Section
Dim hdr As HeaderFooter

Set sec = mydoc.Sections.First
Set hdr = sec.Headers(wdHeaderFooterPrimary)
Set tbl = hdr.Range.Tables(1)

'Set tbl = mydoc.Sections.First.Headers(wdHeaderFooterPrimary).Range.Tables(1)
tbl.Cell(1, 1).Range.Text = "Some text"
tbl.Cell(1, 2).Range.Text = "Some more text"

Open in new window

0
 

Author Closing Comment

by:kaysoo
ID: 39686744
Thx guys for your solution, it works great.
0
 
LVL 76

Expert Comment

by:GrahamSkan
ID: 39686749
Did you find out what member couldn't be found?
0
 

Author Comment

by:kaysoo
ID: 39686753
I believed it was an Access version issue, e.g. Dim tbl As Table doesnt work for me cause my version of VB editor does not have this function, I have to change it to Dim tbl As Object instead.

Dim hdr as HeaderFooter also not classified as a function in my older version of VB editor.

AFter I modified your suggested codes by implementing suggestion from als315

Set tbl = mydoc.Sections.First.Headers(1).Range.Tables(1)

it solved all the compile errors.
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

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

Suggested Solutions

No matter the version of Windows you are using, you may have some problems with Windows Search running too slow or possibly not running at all. Before jumping into how you can solve this issue, just know there are many other viable alternative deskt…
This article will guide you to convert a grid from a picture into Excel format using Microsoft OneNote and no other 3rd party application.
The viewer will learn how to use a discrete random variable to simulate the return on an investment over a period of years, create a Monte Carlo simulation using the discrete random variable, and create a graph to represent the possible returns over…
The viewer will learn how to create a normally distributed random variable in Excel, use a normal distribution to simulate the return on an investment over a period of years, Create a Monte Carlo simulation using a normal random variable, and calcul…

910 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

Need Help in Real-Time?

Connect with top rated Experts

25 Experts available now in Live!

Get 1:1 Help Now