[英]Powershell Run Multiple vba scripts in excel workbook across multiple worksheets
嗨,我需要在同一工作簿中的不同工作表上运行不同的vba脚本。 基本上,每个工作表都有自己的vba脚本,该脚本会触发ODBC连接,然后从数据库更新工作表。 我已经能够使一个vba脚本在一张纸上运行并另存为...没问题,但是最多只能运行一个。 这是我正在使用的代码
$excel = new-object -comobject excel.application
$excelFiles = Get-ChildItem -Path C:\test\Daily_update.xlsm
$Date = (Get-Date -Format dd-MM-yy)
Foreach($file in $excelFiles)
{
$workbook = $excel.workbooks.open($file.fullname)
$worksheet = $workbook.worksheets.item(2)
$excel.Run("Test_Refresh")
$workbook.saveAs("C:\test\Daily_update_$Date.xlsm")
$workbook.close()
}
$excel.quit()
当我尝试添加其他工作表和vba脚本时,它根本不起作用。
离开问题一会儿,再喝点咖啡,并运用一些逻辑后,可以。 我有事情要工作。 因此,以防万一您需要一个脚本来执行我想做的事情,并在同一工作簿中的特定工作表上运行特定宏,就在这里。
$excel = new-object -comobject excel.application
$excelFiles = Get-ChildItem -Path C:\Test\Daily_update.xlsm
$Date = (Get-Date -Format dd-MM-yy)
$workbook = $excel.workbooks.open($excelfiles.fullname)
$WS2 = $workbook.worksheets.item(2)
$WS2.Activate()
$excel.Run("Test_Refresh")
$WS3 = $workbook.worksheets.item(3)
$WS3.Activate()
$excel.Run("test_Refresh_2")
$WS4 = $workbook.worksheets.item(4)
$WS4.Activate()
$excel.Run("test_Refresh_3")
$workbook.saveas("C:\Test\SQL\Daily_update_$Date.xlsm")
$workbook.close()
$excel.quit()
只是增加一点。 经过反复试验,我发现下面的代码比上面的代码运行效率更高。 我还注意到,如果只有3个工作表就可以了,但是任何其他工作表都会引发错误,特别是在调用工作表时。 但是,当工作簿打开并可见时,该问题消失了。
#Call the application
$excel = new-object -comobject excel.application
#Now we select the file and path
$excelFiles = Get-ChildItem -Path "\\Server\Test\Daily_refresh.xlsm"
#The next variable speeds the script up by not calling the comobject as often
$app = $excel.Application
#Get system date and time and format it to comply with the final filename format
$Date = (Get-Date -Format dd-MM-yy)
#And again for the year folder
$Year = (Get-Date -Format yyyy)
#Test if folder exists
$DestYearFolder = "\\Server\Test\Daily_Refresh_Output\Test\$Year"
if (!(Test-Path -path $DestYearFolder)) {New-Item $DestYearFolder -Type Directory}
#Same as above only for the month folder
$Month = (Get-Date -Format MMM)
#Test if folder exists
$DestMonthFolder = "\\Server\Test\Daily_Refresh_Output\Test\$Year\$Month"
if (!(Test-Path -path $DestMonthFolder)) {New-Item $DestMonthFolder -Type Directory}
#Now we open the Excel file and activate the macro enabled content
$workbook = $app.workbooks.open($excelfiles)
#The next command makes Excel visible
$app.Visible = $true
$workbook.Activate()
#Now we run all the Macros that need to be run.
$app.Run("Macro_1")
$app.Run("Macro_2")
$app.Run("Macro_3")
$app.Run("Macro_4")
$app.Run("Macro_5")
$app.Run("Macro_6")
$app.Run("Macro_7")
$app.Run("Macro_8")
$app.Run("Macro_9")
$app.Run("Macro_10")
#Now we save the workbook in the standard daily format and the close Excel
$workbook.saveas("\\Server\Test\Daily_Refresh_Output\Test\$Year\$Month\Daily_Refresh_test_$Date.xlsm")
$workbook.close()
$excel.quit()
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.