Мой обходной путь - записать макрос в файле Excel (поэтому вам нужно использовать расширение файла .xlsm) (сначала вам нужно будет перейти в «Программы»> «Windows Powershell» и ввести в командной строке Set-ExecutionPolicy RemoteSigned
чтобы разрешить запуск сценария) :
Sub AutoUpdate()
'
' AutoUpdate Macro
' data refresh from MSQuery connection
'
Sheets("Feuill1").Select
Selection.ListObject.QueryTable.Refresh BackgroundQuery:=False
End Sub
Затем я использую скрипт Powershell, который делает свое дело: открывает файл Excel, вызывает макрос, сохраняет и закрывает файл.
В этом примере я делаю копию исходного файла в целях безопасности / резервного копирования, но, конечно, вы можете сохранить сам исходный файл.
$objectExcel = new-object -c excel.application
$objectExcel.displayAlerts = $false # don't prompt the user
#$objectExcel.visible = $True;
$Classeur = $objectExcel.workbooks.open("source_filepath", $null, $true)
$objectExcel.run("AutoUpdate")
# $objectExcel.run("RemoveODBC") # another custom macro for removing data connexion
$Classeur.saveas("destination_filepath")
$Classeur.close($false)
#$objectExcel.visible = $False;
$objectExcel.quit()
spps -n excel
Поэтому мой отчет Excel обновляется ежедневно, без какого-либо ручного вмешательства, с помощью задачи Windows Planified, которая вызвала вышеуказанный сценарий.