Solved

Access 2003 VBA to Duplicate a MS Word Table

Posted on 2014-04-26
5
1,274 Views
Last Modified: 2014-04-27
Dear Experts,

I am using Access 2003 to design a Solution where I required to click a command button from Access Form to transfer a recordset to an opened Word Document.

Assuming in the opened Word Document already contained a single template table(1), but if I need to programmatically create a second table(2) based on the template table(1), the copied table(2) should be located under the template table(1) in the same Word Document Page separated by a single paragraph, how do I do it?

I hv no problem transferring the Access recordset into the table(1), I just need the vba code to duplicate an extra table from template table in same Word page if needed.

Thanks in advance.
0
Comment
Question by:kaysoo
[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
  • 2
  • 2
5 Comments
 
LVL 39

Accepted Solution

by:
thenelson earned 300 total points
ID: 40025044
If I understand you correctly.

To copy the table:
    Selection.Tables(1).Select
    Selection.Copy

Then move to where you want to paste the copy. One move example:
    Selection.MoveDown Unit:=wdLine, Count:=1

Then paste what you copied:
    Selection.PasteAndFormat (wdPasteDefault)
0
 

Author Comment

by:kaysoo
ID: 40025370
Tq for your reply Mr thenelson, yes you understand my request for help correctly.

I tried your code, there are no syntax error but the Table wasn't copied and pasted as planned too, then MS Access 2003 pop up a message saying "OBJECT REQUIRE".

What is that means?

I attached a sample document for ref and the coding as well.

Private Sub Command96_Click()
On Error GoTo Err_Command96_Click

   
Dim db As DAO.Database
    Dim rs As DAO.Recordset
    Dim wd As Object
   
    Set wd = CreateObject("Word.Application")
    Set mydoc = wd.Documents.Open("C:\Program Files\Test.docx")
    Set db = CurrentDb()
    wd.Visible = True
     
    'To copy the table:
    Selection.Tables(1).Select
    Selection.Copy
   
    'Then move to where you want to paste the copy. One move example:
    Selection.MoveDown Unit:=wdLine, Count:=100
       
       
    'Then paste what you copied:
    Selection.PasteAndFormat (wdPasteDefault)
   
   
   
Exit_Command96_Click:
    Exit Sub

Err_Command96_Click:
    MsgBox Err.Description
    Resume Exit_Command96_Click
End Sub
Sample-Word-Doc.jpg
0
 
LVL 51

Assisted Solution

by:Rgonzo1971
Rgonzo1971 earned 200 total points
ID: 40025607
Hi,

pls try

Const wdLine = 5
Const wdPasteDefault = 0
    Set wd = CreateObject("Word.Application")
    Set mydoc = wd.Documents.Open("C:\Program Files\Test.docx")
    Set db = CurrentDb()
    wd.Visible = True
      
    'To copy the table:
    wd.Selection.Tables(1).Select
    wd.Selection.Copy
    
    'Then move to where you want to paste the copy. One move example:
    wd.Selection.MoveDown Unit:=wdLine, Count:=100
        
        
    'Then paste what you copied:
    wd.Selection.PasteAndFormat (wdPasteDefault)

Open in new window

Regards
0
 

Author Closing Comment

by:kaysoo
ID: 40025968
Thanks guys, both of your advice gave me a big help with some slight modification of my own.

'To copy the table:
    wd.Selection.Tables(1).Select
    wd.Selection.Copy

Changed to:

'To copy the table:
    mydoc.Tables(1).Select
    wd.Selection.Copy

the rest of the codes were combination from both comments and it copy and paste as intended.

Thanks again.
0
 
LVL 39

Expert Comment

by:thenelson
ID: 40025998
Your welcome, glad I could help.
0

Featured Post

Free Tool: SSL Checker

Scans your site and returns information about your SSL implementation and certificate. Helpful for debugging and validating your SSL configuration.

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

As tax season makes its return, so does the increase in cyber crime and tax refund phishing that comes with it
Access developers frequently have requirements to interact with Excel (import from or output to) in their applications.  You might be able to accomplish this with the TransferSpreadsheet and OutputTo methods, but in this series of articles I will di…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…
Do you want to know how to make a graph with Microsoft Access? First, create a query with the data for the chart. Then make a blank form and add a chart control. This video also shows how to change what data is displayed on the graph as well as form…

734 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