簡體   English   中英

Powershell - 在 Powershell ISE 中,在 Powershell 中運行多行腳本

[英]Powershell - Within Powershell ISE run multiple line script in Powershell

我有一個在 Powershell ISE 中運行的腳本,但該腳本的一部分必須在常規 Powershell 中運行。 需要在 Powershell 中運行的腳本有多行。

當我嘗試像這樣運行腳本時:

<#
Some code runs up here
#>

$script = {
$PW = "Password1";
$PW = $PW | ConvertTo-SecureString -AsPlainText -Force;
Add-SQLAssessmentTask -ManagementGroup "SOME_ID_NUMBER"  -SQLServerName $env:computername -WorkingDirectory C:\Temp\SQL -ScheduledTaskUsername domain\user -ScheduledTaskPassword $PW -Verbose;
}

$command = $script.ToString()

#Start-Process powershell -argumentlist $command

Start-Process powershell -argumentlist $script

我收到以下錯誤: 在此處輸入圖片說明

當我像這樣運行腳本時:

<#
Some code runs up here
#>

$arguments = "$PW = ""Password1""","$PW = $PW | ConvertTo-SecureString -AsPlainText -Force","Add-SQLAssessmentTask -ManagementGroup ""SOME_ID_NUMBER""  -SQLServerName $env:computername -WorkingDirectory C:\Temp\SQL -ScheduledTaskUsername domain\user -ScheduledTaskPassword $PW -Verbose" 

Start-Process powershell -argumentlist $arguments

我收到此錯誤: 在此處輸入圖片說明

如果我在常規 Powershell 中運行每一行,一次一個,它工作正常。

有什么建議?

如果您想運行多個命令, $Arguments應該是一個由分號分隔的腳本塊。

$arguments = {"$PW = ""Password1""";"$PW = $PW | ConvertTo-SecureString -AsPlainText -Force";"Add-SQLAssessmentTask -ManagementGroup ""SOME_ID_NUMBER""  -SQLServerName $env:computername -WorkingDirectory C:\Temp\SQL -ScheduledTaskUsername domain\user -ScheduledTaskPassword $PW -Verbose" }

Start-Process powershell -argumentlist $arguments

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM