Error » Microsoft Error! » Microsoft office error » Need help automating a MS Access Report --> MS Excel macro; way to make Access run Ex

Microsoft office error all errors related to Microsoft office error

Post New Thread Reply
  Need help automating a MS Access Report --> MS Excel macro; way to make Access run Ex
LinkBack Thread Tools Display Modes
Old 28-Mar-2007, 01:08 AM   #1 (permalink)
Fixed Error!
 
Iphone's Avatar

Posts: 4,202
Join Date: Mar 2007
Rep Power: 6 Iphone is on a distinguished road

IM:
Default Need help automating a MS Access Report --> MS Excel macro; way to make Access run Ex

I have been tasked with creating a report in MS Access and creating an identical report in MS Excel.

I had no trouble creating/formatting the MS Access report but "exporting" it to Excel proved problematic.

I learned that it's not possible to do a quick-and-dirty export so I decided I would use an Excel macro to take the horribly out-of-whack spreadsheet that resulted from the MS Access report and output it in a more presentable format.

So, at present these are the steps in this process:

1. Run report (rpt_loans) in MS Access
2. Tools --> Office Links --> Analyze it with Microsoft Excel
3. Excel file opens (rpt_loans.xls)
4. I need to open the Excel file (called "loansrpt_macro.xls") in which I wrote the formatting Macro
5. alt+tab from loansrpt_macro.xls to rpt_loans.xls
6. hit alt+F8, make sure "All Open Workbooks" option is chosen from the "Macros in:" drop down menu
7. click "Run"

As you can see this is a bit of an involved process. It's not at all difficult for me or any minimally computer savvy person to do but because many different people in my company need to access this report in both Access and Excel format, I'm looking for a way to make the process simpler and more automated.

Any suggestions as to how I can have this done in a quicker and easier way? *Ideally*, I would like to create a button in Access that actually does steps 1 through 7 above, it runs the Access report, exports it to Excel and runs the loansrpt_macro.xls Macro on the exported file, resulting in a clean and prepared Excel spreadsheet ready to be used.

Anybody have any idea if this is possible and, if so, how I can do it?
Iphone is offline  
Digg this Post!Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!Spurl this Post!Reddit!
Reply With Quote
   


   
Old 28-Mar-2007, 01:08 AM   #2 (permalink)
Fixed Error!
 
Iphone's Avatar

Posts: 4,202
Join Date: Mar 2007
Rep Power: 6 Iphone is on a distinguished road

IM:
Default Re: Need help automating a MS Access Report --> MS Excel macro; way to make Access ru

You can try something like the following. This assumes that your file loansrpt_macro.xls resides in a work directory, in which the reports will be created also.

Note that you can change your Excel file to an xla, so that you can then run macros from it without specifying the name of the file each time, but that isn't very important. Note also that you can save your excel file in hidden mode ("window / hide") so that it won't be visible to the users.

Make sure you add a reference to the excel library (tools / references) and start with this Access module:

-------------------------------------------------------------------------------------
Option Compare Database
Option Explicit

Const cWorkDir = "C:\documents and settings\broohaha9\desktop\"
Const cTools = "loansrpt_macro.xls"

Function LoadTools(pappXL As Excel.Application) As Boolean
'
' Attempt to run a dummy macro from my excel tools workbook.
' On failure, attempt to open the workbook and try again.
'
On Error Resume Next
pappXL.Run cTools & "!DummyMacro"
If Err Then
Err.Clear
pappXL.Workbooks.Open cWorkDir & cTools
pappXL.Run cTools & "!DummyMacro"
End If

LoadTools = (Err.Number = 0)
If Err Then Err.Clear

End Function

Sub ExcelReport()
'
' Open report, export to Excel and run a formatting macro.
'
Dim xlwkbReport As Excel.Workbook

' change to work folder:
ChDir cWorkDir
' open report, export, and close
DoCmd.OpenReport "rpt_loans", acViewPreview
RunCommand acCmdOutputToExcel
DoCmd.Close acReport, "rpt_loans"

' get handle to workbook and run formatting macro
Set xlwkbReport = GetObject(cWorkDir & "rpt_loans.xls")
If Not LoadTools(xlwkbReport.Application) Then Exit Sub
xlwkbReport.Application.Run cTools & "!FormattingMacro"

End Sub
-------------------------------------------------------------------------------------

Your Excel module (in loansrpt_macro.xls) would be build according to this:

-------------------------------------------------------------------------------------
Option Explicit

Sub FormattingMacro()

Windows("rptForExcel.xls").Activate
' recorded formatting instructions from here...

End Sub

Sub DummyMacro()
' do nothing...
End Sub
-------------------------------------------------------------------------------------

I believe the above covers your points 1 through 7.
Happy programming!
Iphone is offline  
Digg this Post!Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!Spurl this Post!Reddit!
Reply With Quote
Post New Thread Reply


Currently Active Users Viewing This Thread: 1 (0 members and 1 guests)
 
Thread Tools
Display Modes

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On
Forum Jump


All times are GMT -8. The time now is 01:21 PM.

Powered by vBulletin® Version 3.7.2
Copyright ©2000 - 2008, Jelsoft Enterprises Ltd.
Search Engine Friendly URLs by vBSEO 3.2.0

DMCA Policy

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228