currently can run 2 excel vba processes simultaniously within 2 seperate excel instances on 1 pc.
my goal import data excel instance 2 excel instance 1 every minute.
unfortunately not possible connect workbook in excel instance 1 open workbook in excel instance 2.
since can connect saved workbook, solution save workbook in instance 2 every minute , retrieve new data saved workbook.
although rather heavy method. there better solution connect open workbook in instance of excel?
(to open workbook in same instance no solution since in case can no longer run 2 vba processes simultaniously.)
thanks!
short version
option explicit public sub getdatafromexternalxlinstance() dim instancefile object, ur variant, lr long 'if not open, getobject() open in new instance set instancefile = getobject("c:\tmp\testdata2.xlsx") '(code running testdata1) ur = instancefile.worksheets(2).usedrange 'get used range 2nd worksheet activesheet lr = .cells(.rows.count, "a").end(xlup).row + 1 'last row on active sheet .range(.cells(lr, "a"), .cells(ubound(ur) + lr - 1, ubound(ur, 2))) = ur end 'instancefile.close 'set instancefile = nothing end sub
long version using api calls (from excel file getobject()
)
option explicit #if vba7 'or: #if win64 'win64=true, win32=true, win16= false private declare ptrsafe function findwindow lib "user32" alias "findwindowa" (byval lpclassname string, byval lpwindowname string) long private declare ptrsafe function sendmessage lib "user32" alias "sendmessagea" (byval hwnd long, byval wmsg long, byval wparam long, lparam any) long #else declare function findwindow lib "user32" alias "findwindowa" (byval lpclassname string, byval lpwindowname long) long declare function sendmessage lib "user32" alias "sendmessagea" (byval hwnd long,byval wmsg long, byval wparam long, byval lparam long) long #end if public sub getdatafromexternalxlinstanceapi() dim xlapp object dim xlnotrunning boolean 'flag final reference release on error resume next 'check if excel running; defer error trapping set xlapp = getobject(, "excel.application") 'if it's not running error occurs xlnotrunning = (err.number <> 0) err.clear 'clear err object in case of error on error goto 0 'reset error trapping detectexcel 'if excel running enter running object table set xlapp = getobject("c:\tmp\testdata2.xlsx") 'set object reference file 'show excel through application property xlapp.application.visible = true 'show actual window of file using windows collection of xlapp object ref xlapp.parent.windows(1).visible = true '... process file 'if excel not running when started, close using app's quit method if xlnotrunning = true xlapp.application.quit set xlapp = nothing 'release reference application , spreadsheet end sub
public sub detectexcel() 'this procedure detects running excel app , registers const wm_user = 1024 dim hwnd long hwnd = findwindow("xlmain", 0) 'if excel running api call returns handle if hwnd = 0 exit sub '0 means excel not running 'else excel running use sendmessage api function 'to enter in running object table sendmessage hwnd, wm_user + 18, 0, 0 end sub
Comments
Post a Comment