Автоматический импорт макроса в Excel и его запуск

Я сделал модуль, т. е. .bas файл, который делает работу, которую я хочу сделать в Excel. Я должен работать с этим же модулем в четырех разных файлах каждый день.

теперь я хочу, скажем, скрипт, который автоматически связывает этот модуль с файлом Excel, а затем макрос выполняется сам по себе.

кусок кода, который я пробовал до сих пор:

Option Explicit

On Error Resume Next

ExcelMacroExample

Sub ExcelMacroExample() 

  Dim xlApp 
  Dim xlBook 

  Set xlApp = CreateObject("Excel.Application") 
  Set xlBook = xlApp.Workbooks.Open("C:Denied_report.csv", 0, True) 
  xlApp.Run "PERSONAL.XLSB!AllowedMacro"
  xlApp.SaveAs
  xlApp.ActiveWorkbook.Close
  xlApp.Quit 

  Set xlBook = Nothing 
  Set xlApp = Nothing 

End Sub 

Я использую личный файл, чтобы он был доступен для всех файлов Excel и не должен импортируйте его каждый раз, открыв файл Excel и сделав это!

2
задан slhck
02.02.2023 0:08 Количество просмотров материала 3514
Распечатать страницу

2 ответа

вы можете попробовать функцию Workbook_open. Это будет работать, как только вы открываете Excel.

Public WithEvents App As Application

Private Sub Workbook_Open()
    'runs once per Excel session when Personal.xlsb is opened.
    Set App = Application
    MsgBox "Running Workbook_Open from Personal.xlsb"
End Sub

Private Sub App_WorkbookOpen(ByVal Wb As Workbook)
    MsgBox "Running App_WorkbookOpen in " & Wb.Name
    'add code you want to run upon opening each workbook here
   '.....
End Sub

см.: http://www.mrexcel.com/forum/excel-questions/562394-workbook_open-personal-xlsb-problems-need-correct-sub-procedure.html

1
отвечен Robert Ilbrink 2023-02-03 07:56

я попробовал это, и это сработало:

Option Explicit

    LaunchMacro

  Sub LaunchMacro() 
      Dim xl
      Dim xlBook      
      Dim strFile


        strFile = "C:\De1.csv"
        Set xl = CreateObject("Excel.application")
        Set xlBook = xl.Workbooks.Open("C:\De.csv", 0, False ) 

        xl.Application.Visible = True

        xl.Application.run "PERSONAL.XLSB!Allowed_Macro"
        xl.DisplayAlerts = False        
        xlBook.saved = True
        xl.ActiveWorkbook.SaveAs strFile

        xl.activewindow.close
        xl.Quit

        Set xlBook = Nothing
        Set xl = Nothing

End Sub 

единственная проблема, с которой я сталкиваюсь сейчас, заключается в том, что я форматирую свой макрос, они не сохраняются после сохранения.

0
отвечен Developer by Blood 2023-02-03 10:13

Постоянная ссылка на данную страницу: [ Скопировать ссылку | Сгенерировать QR-код ]

Ваш ответ

Опубликуйте как Гость или авторизуйтесь

Имя

Похожие вопросы про тегам:

batch
macros
microsoft-excel
microsoft-excel-2010
vba
Вверх