ChatGPT解决这个技术问题 Extra ChatGPT

如何在 PowerShell 中使用带空格和引号的参数运行 EXE 文件

如何在 PowerShell 中运行以下命令?

C:\Program Files\IIS\Microsoft Web Deploy\msdeploy.exe -verb:sync -source:dbfullsql="Data Source=mysource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;" -dest:dbfullsql="数据源=.\mydestsource;Integrated Security=false;用户ID=sa;密码=sapass!;数据库=mydb;",computername=10.10.10.10,username=administrator,password=adminpass"

如果您的意思是“在 PowerShell 中”(我将其解释为“在现有 PowerShell 提示符内)”,那么可以轻松地修改以下示例以满足您的需求。请注意,无需将命令与其参数分开:{1 }
我不知道如何使用“mini-markdown”来编辑上面的注释,使每一行代码出现在单独的行上,并且编辑原始注释的 5 分钟时间限制已过期。如果现在有人知道使用“mini-Markdown”来解决问题,我会以更易读的形式重新发布。第一行应该如下: # 使用 npm-check-updates 工具显示全局安装的 npm 包的任何可用更新
我从来不知道评论能够允许不同的行。我认为,对于评论中的链接,降价功能仅限于 backticks 和 ()[]。

P
Peter Mortensen

当 PowerShell 看到以字符串开头的命令时,它只会评估该字符串,也就是说,它通常会将其回显到屏幕上,例如:

PS> "Hello World"
Hello World

如果您希望 PowerShell 将字符串解释为命令名称,请使用调用运算符 (&),如下所示:

PS> & 'C:\Program Files\IIS\Microsoft Web Deploy\msdeploy.exe'

之后,您可能只需要引用包含空格和/或引号字符的参数/参数对。当您使用复杂的命令行参数调用这样的 EXE 文件时,拥有一个工具来向您展示 PowerShell 如何将参数发送到 EXE 文件通常会很有帮助。 PowerShell Community Extensions 有这样的工具。它被称为回声参数。您只需将 EXE 文件替换为 echoargs - 保留所有参数,它将向您展示 EXE 文件将如何接收参数,例如:

PS> echoargs -verb:sync -source:dbfullsql="Data Source=mysource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;" -dest:dbfullsql="Data Source=.\mydestsource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;",computername=10.10.10.10,username=administrator,password=adminpass

Arg 0 is <-verb:sync>
Arg 1 is <-source:dbfullsql=Data>
Arg 2 is <Source=mysource;Integrated>
Arg 3 is <Security=false;User>
Arg 4 is <ID=sa;Pwd=sapass!;Database=mydb;>
Arg 5 is <-dest:dbfullsql=Data>
Arg 6 is <Source=.\mydestsource;Integrated>
Arg 7 is <Security=false;User>
Arg 8 is <ID=sa;Pwd=sapass!;Database=mydb; computername=10.10.10.10 username=administrator password=adminpass>

使用 echoargs 您可以进行试验,直到正确为止,例如:

PS> echoargs -verb:sync "-source:dbfullsql=Data Source=mysource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;"
Arg 0 is <-verb:sync>
Arg 1 is <-source:dbfullsql=Data Source=mysource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;>

事实证明,我之前太努力维护连接字符串周围的双引号。显然这不是必需的,因为即使是 cmd.exe 也会删除它们。

顺便说一句,向 PowerShell 团队致敬。他们非常有帮助向我展示了单曲和单曲的具体咒语。双引号以获得所需的结果 - 如果您需要保留内部双引号。 :-) 他们也意识到这是一个痛苦的领域,但他们受到受特定问题影响的人数的驱动。如果这对您来说是一个痛苦的领域,那么请对此PowerShell bug submission投赞成票。

有关 PowerShell 如何解析的更多信息,请查看我的 Effective PowerShell blog series - 特别是 item 10 - "Understanding PowerShell Parsing Modes"

2012 年 4 月 4 日更新:这种情况在 PowerShell V3 中变得更容易处理。请参阅此blog post for details


如果用作第二个示例,我会收到此错误:错误:无法识别的参数 '"-source:dbfullsql="""Data'。所有参数必须以“-”开头。
对不起,我不明白。我看到,目前有 6 人对答案投了赞成票,所以我遗漏了一些明显的东西,但实际答案是什么?是否有一个特殊的规则可以使用 PowerShell 了解带空格的参数,或者您只是建议逐个案例使用 EchoArgs 来帮助?
引用论点通常就足够了,但并非总是如此。在它不起作用的情况下,使用 echoargs 可以指示 PowerShell 在将参数传递到 EXE 之前如何解释它们。
您知道我将如何在 .bat 文件中执行此操作吗?我正在控制台中直接尝试 & 'C:\Program Files\Sublime Text 3\sublime_text.exe' 并且它正在工作,但在批处理文件中我收到一条错误消息“&在这个时候是出乎意料的。
没关系。找到它:START C:\"Program Files"\"Sublime Text 3"\sublime_text.exe
A
Adi Inbar

只需在 .exe 名称前添加 & 运算符即可。以下是在静默模式下安装 SQL Server Express 的命令:

$fileExe = "T:\SQLEXPRADV_x64_ENU.exe"
$CONFIGURATIONFILE = "T:\ConfSetupSql2008Express.ini"

& $fileExe  /CONFIGURATIONFILE=$CONFIGURATIONFILE

S
Sabuncu

我在命令和参数中都有空格,这对我有用:

$Command = "E:\X64\Xendesktop Setup\XenDesktopServerSetup.exe"
$Parms = "/COMPONENTS CONTROLLER,DESKTOPSTUDIO,DESKTOPDIRECTOR,LICENSESERVER,STOREFRONT /PASSIVE /NOREBOOT /CONFIGURE_FIREWALL /NOSQL"

$Parms = $Parms.Split(" ")
& "$Command" $Parms

它与 Akira 的答案基本相同,但如果您动态构建命令参数并将它们放入变量中,则此方法有效。


恕我直言,这是最好的!没有 base64,没有奇怪的 --% 切换替换的语法,正常的 powershell 替换规则,没有混淆,非常易读。
这行不通。如果你的参数里面有路径名,那么路径名会被分成多个参数。
不错的答案。但是,它可以与参数中的引号一起使用吗?
请尝试这个,在其他一切实际工作之后。还可以使用 Powershell 扩展 EchoArgs
.Split(" ") 是这个答案的关键部分,使它对我有用
C
Community

您可以使用很多方法来做到这一点。

还有其他方法,例如使用调用运算符 (&)、Invoke-Expression cmdlet 等。但它们被认为是不安全的。 Microsoft 建议使用 Start-Process。

方法一

一个简单的例子

Start-Process -NoNewWindow -FilePath "C:\wamp64\bin\mysql\mysql5.7.19\bin\mysql" -ArgumentList "-u root","-proot","-h localhost"

在你的情况下

Start-Process -NoNewWindow -FilePath "C:\Program Files\IIS\Microsoft Web Deploy\msdeploy.exe" -ArgumentList "-verb:sync","-source:dbfullsql=`"Data Source=mysource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;`"","-dest:dbfullsql=`"Data Source=.\mydestsource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;`"","computername=10.10.10.10","username=administrator","password=adminpass"

在此方法中,您使用逗号分隔 ArgumentList 中的每个参数。

方法二

简单示例

Start-Process -NoNewWindow -FilePath "C:\wamp64\bin\mysql\mysql5.7.19\bin\mysql" -ArgumentList "-u root -proot -h localhost"

在你的情况下

Start-Process -NoNewWindow -FilePath "C:\Program Files\IIS\Microsoft Web Deploy\msdeploy.exe" -ArgumentList "-verb:sync -source:dbfullsql=`"Data Source=mysource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;`" -dest:dbfullsql=`"Data Source=.\mydestsource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;`",computername=10.10.10.10,username=administrator,password=adminpass"

这种方法更容易,因为它允许一次性输入参数。

请注意,在 powershell 中,要表示字符串中的引号 ("),您应该插入重音符号 (`)(这是美式键盘中 Tab 键上方的键)。 -NoNewWindow 参数用于在当前控制台窗口。默认情况下,Windows PowerShell 会打开一个新窗口。

参考文献:Powershell/Scripting/Start-Process


简单总是赢!谢谢。
感谢您对转义引号的最后说明!
A
Akira Yamamoto

这对我有用:

& 'D:\Server\PSTools\PsExec.exe' @('\\1.1.1.1', '-accepteula', '-d', '-i', $id, '-h', '-u', 'domain\user', '-p', 'password', '-w', 'C:\path\to\the\app', 'java', '-jar', 'app.jar')

只需将路径或连接字符串放入一个数组项中,然后将其他内容分别拆分为一个数组项。

这里还有很多其他选项:https://social.technet.microsoft.com/wiki/contents/articles/7703.powershell-running-executables.aspx

Microsoft 应该使这种方式更简单并与命令提示符语法兼容。


Array 绝对是最好的选择——这对我来说非常有用。除了我传递了一个数组变量,因为我的参数是动态的。谢谢。
恕我直言,最佳解决方案
B
Baodad

请参阅此页面:https://slai.github.io/posts/powershell-and-external-commands-done-right/

使用 vshadow 作为外部可执行文件的总结:

$exe = "H:\backup\scripts\vshadow.exe"
&$exe -p -script=H:\backup\scripts\vss.cmd E: M: P:

D
Darkgaze

如果有人想知道如何运行一个可执行文件:

..... > .\file.exe

或者

......>完整\路径\到\file.exe


这应该是该问题的答案,当我们使用“从 PowerShell 启动 EXE”关键字时,我们正在寻找它。谢谢 !
带着参数跑怎么样?
@SereneWizard 好吧,在 .exe 之后添加它们,中间有一个空格。示例:.\file.exe 参数 1 参数 2 参数 3
一旦命令名称中有空格,这将失败。然后你必须将命令用引号括起来。然后它会被 Powershell 认为只是一个字符串,并且只会输出,而不是启动命令,这让我们回到了 OP 的问题。
这应该被认为是正确的答案。
B
B--rian

您可以使用:

Start-Process -FilePath "C:\Program Files\IIS\Microsoft Web Deploy\msdeploy.exe" -ArgumentList "-verb:sync -source:dbfullsql="Data Source=mysource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;" -dest:dbfullsql="Data Source=.\mydestsource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;",computername=10.10.10.10,username=administrator,password=adminpass"

根据帮助指南,这里要注意的关键是 FilePath 必须位于位置 0。要调用命令行开关的帮助指南,只需输入 Get-Help <Commandlet-name> -Detailed 。在这种情况下,它是 Get-Help Start-Process -Detailed


G
G-Mac

我能够使用以下方法使我的类似命令工作:

msdeploy.exe -verb=sync "-source=dbFullSql=Server=THESERVER;Database=myDB;UID=sa;Pwd=saPwd" -dest=dbFullSql=c:\temp\test.sql

对于您的命令(现在不是很有帮助),事情看起来像这样:

msdeploy.exe -verb=sync "-source=dbfullsql=Server=mysource;Trusted_Connection=false;UID=sa;Pwd=sapass!;Database=mydb;" "-dest=dbfullsql=Server=mydestsource;Trusted_Connection=false;UID=sa;Pwd=sapass!;Database=mydb;",computername=10.10.10.10,username=administrator,password=adminpass

关键点是:

在源参数周围使用引号,并删除连接字符串周围的嵌入引号

在构建其中不包含空格的 SQL 连接字符串时使用替代键名称。例如,使用“UID”而不是“User Id”、“Server”而不是“Data Source”、“Trusted_Connection”而不是“Integrated Security”等等。只有从连接字符串中删除所有空格后,我才能让它工作。

我没有尝试在命令行末尾添加“计算机名”部分,但希望此信息将帮助其他阅读本文的人更接近他们想要的结果。


我尝试了所有其他答案,但这是唯一对我有用的答案!感谢您提供此替代路径。
一旦命令名称中有空格,这将失败。然后你必须将命令用引号括起来。然后它会被 Powershell 认为只是一个字符串,并且只会输出,而不是启动命令,这让我们回到了 OP 的问题。
P
Peter Mortensen

PowerShell V3 中的新转义字符串,引用自 New V3 Language Features

从 Cmd.exe 更容易重用命令行

网络上到处都是为 Cmd.exe 编写的命令行。这些命令行在 PowerShell 中经常工作,但是当它们包含某些字符时,例如分号 (;)、美元符号 ($) 或花括号,您必须进行一些更改,可能会添加一些引号。这似乎是许多轻微头痛的根源。

为了帮助解决这种情况,我们添加了一种“逃避”命令行解析的新方法。如果您使用魔术参数 --%,我们将停止对您的命令行的正常解析并切换到更简单的东西。我们不匹配引号。我们不止于分号。我们不扩展 PowerShell 变量。如果您使用 Cmd.exe 语法(例如 %TEMP%),我们会扩展环境变量。除此之外,直到行尾的参数(或管道,如果您是管道)按原样传递。这是一个例子:

PS> echoargs.exe --% %USERNAME%,this=$something{weird}
Arg 0 is <jason,this=$something{weird}>

S
SwissCodeMen

我使用这种简单、干净、有效的方法。

我将参数放在一个数组中,每行 1 个。这种方式很容易阅读和编辑。然后我使用一个简单的技巧,将双引号内的所有参数传递给具有 1 个单参数的函数。这会将它们(包括数组)扁平化为单个字符串,然后我使用 PS 的“Invoke-Expression”执行该字符串。该指令专门设计用于将字符串转换为可运行命令。效果很好:

# function with one argument will flatten 
# all passed-in entries into 1 single string line
Function Execute($command) {
    # execute:
    Invoke-Expression $command;
    # if you have trouble try:
    # Invoke-Expression "& $command";
    # or if you need also output to a variable
    # Invoke-Expression $command | Tee-Object -Variable cmdOutput;
}

#  ... your main code here ...

# The name of your executable app
$app = 'my_app.exe';
# List of arguments:
# Notice the type of quotes - important !
# Those in single quotes are normal strings, like 'Peter'
$args = 'arg1',
        'arg2',
        $some_variable,
        'arg4',
        "arg5='with quotes'",
        'arg6',
        "arg7 \ with \ $other_variable",
        'etc...';
    
# pass all arguments inside double quotes
Execute "$app $args";
  

D
Daniel Lidström

我尝试了所有建议,但仍然无法使用包含空格的参数运行 msiexec.exe。所以我的解决方案最终使用了 System.Diagnostics.ProcessStartInfo

# can have spaces here, no problems
$settings = @{
  CONNECTION_STRING = "... ..."
  ENTITY_CONTEXT = "... ..."
  URL = "..."
}

$settingsJoined = ($settings.Keys | % { "$_=""$($settings[$_])""" }) -join " "
$pinfo = New-Object System.Diagnostics.ProcessStartInfo
$pinfo.WorkingDirectory = $ScriptDirectory
$pinfo.FileName = "msiexec.exe"
$pinfo.RedirectStandardError = $true
$pinfo.RedirectStandardOutput = $true
$pinfo.UseShellExecute = $false
$pinfo.Arguments = "/l* install.log /i installer.msi $settingsJoined"
$p = New-Object System.Diagnostics.Process
$p.StartInfo = $pinfo
$p.Start() | Out-Null
$stdout = $p.StandardOutput.ReadToEnd()
$p.WaitForExit()

在等待退出之后,不要使用 ReadToEnd() 从 StandardOutput 读取 。它会造成死锁。将它放在方法“WaitForExit()”之前参见:Microsoft Docs - Diagnostic.Process Class
@ptr2n0 谢谢,已修复!
m
marsze

您可以在 powershell 中以不同的方式运行 exe 文件。例如,如果你想运行 unrar.exe 并提取一个 .rar 文件,你可以简单地在 powershell 中编写:

$extract_path = "C:\Program Files\Containing folder";
$rar_to_extract = "C:\Path_to_arch\file.rar"; #(or.exe if its a big file)  
C:\Path_here\Unrar.exe x -o+ -c- $rar_to_extract $extract_path;

但有时,这不起作用,因此您必须使用 & 参数,如上所示:例如,使用 vboxmanage.exe(管理 virtualbox 虚拟机的工具),您必须像这样在字符串之外调用参数,不带引号:

> $vmname = "misae_unrtes_1234123"; #(name too long, we want to change this)
> & 'C:\Program Files\Oracle\VirtualBox\VBoxManage.exe' modifyvm $vmname --name UBUNTU;

如果您只想将 winrar 归档文件调用为 .exe 文件,您还可以使用 invoke-command cmdlet 和 Silent 参数 /S 将其解压缩(它会将自身解压缩到与压缩位置相同的文件夹中)。

> Invoke-Command -ScriptBlock { C:\Your-path\archivefile.exe /S };

因此,有几种方法可以在 powershell 中运行带有参数的 .exe 文件。

有时,必须找到一种解决方法才能使其正常工作,这可能需要进一步的努力和痛苦:) 取决于 .exe 的编译方式或创建者的方式。


j
js2010

Cmd 可以处理运行引用的 exe,但 Powershell 不能。我只是要处理运行 exe 本身,因为我没有它。如果您确实需要将双引号发送到外部命令的参数,那是另一个已在其他地方讨论过的问题。

1) 将 exe 文件夹添加到您的路径中,可能在您的 $profile 中

$env:path += ';C:\Program Files\IIS\Microsoft Web Deploy\'
msdeploy

2)反引号空格:

C:\Program` Files\IIS\Microsoft` Web` Deploy\msdeploy.exe

T
Tony Wall

这对我有用:

PowerShell.exe -Command "& ""C:\Some Script\Path With Spaces.ps1"""

关键似乎是整个命令用外引号括起来,“&”与号用于指定正在执行的另一个子命令文件,然后最后用空格在路径/文件名周围转义(双双)引号在你想首先执行。

这也完成了 MS 连接问题的唯一解决方法,即 -File 不回传非零返回代码,而 -Command 是唯一的替代方法。但到目前为止,人们认为 -Command 的一个限制是它不支持空格。我也更新了该反馈项。

http://connect.microsoft.com/PowerShell/feedback/details/750653/powershell-exe-doesn-t-return-correct-exit-codes-when-using-the-file-option


这与 ops 问题无关,他在他的帖子中专门询问了如何在 powershell 中运行长命令。不是如何在文件路径中运行带有空格的 powershell 脚本。
阅读问题的标题,空格是问题而不是长度。这是对此类问题的一个有效答案,因此值得分享。您是否有同样的问题并实际尝试过?如果您想改进它,请提交包含问题中实际命令的编辑,我会接受。
A
Almett

另一种答案是使用 Base64 编码的命令开关:

powershell -EncodedCommand "QwA6AFwAUAByAG8AZwByAGEAbQAgAEYAaQBsAGUAcwBcAEkASQBTAFwATQBpAGMAcgBvAHMAbwBmAHQAIABXAGUAYgAgAEQAZQBwAGwAbwB5AFwAbQBzAGQAZQBwAGwAbwB5AC4AZQB4AGUAIAAtAHYAZQByAGIAOgBzAHkAbgBjACAALQBzAG8AdQByAGMAZQA6AGQAYgBmAHUAbABsAHMAcQBsAD0AIgBEAGEAdABhACAAUwBvAHUAcgBjAGUAPQBtAHkAcwBvAHUAcgBjAGUAOwBJAG4AdABlAGcAcgBhAHQAZQBkACAAUwBlAGMAdQByAGkAdAB5AD0AZgBhAGwAcwBlADsAVQBzAGUAcgAgAEkARAA9AHMAYQA7AFAAdwBkAD0AcwBhAHAAYQBzAHMAIQA7AEQAYQB0AGEAYgBhAHMAZQA9AG0AeQBkAGIAOwAiACAALQBkAGUAcwB0ADoAZABiAGYAdQBsAGwAcwBxAGwAPQAiAEQAYQB0AGEAIABTAG8AdQByAGMAZQA9AC4AXABtAHkAZABlAHMAdABzAG8AdQByAGMAZQA7AEkAbgB0AGUAZwByAGEAdABlAGQAIABTAGUAYwB1AHIAaQB0AHkAPQBmAGEAbABzAGUAOwBVAHMAZQByACAASQBEAD0AcwBhADsAUAB3AGQAPQBzAGEAcABhAHMAcwAhADsARABhAHQAYQBiAGEAcwBlAD0AbQB5AGQAYgA7ACIALABjAG8AbQBwAHUAdABlAHIAbgBhAG0AZQA9ADEAMAAuADEAMAAuADEAMAAuADEAMAAsAHUAcwBlAHIAbgBhAG0AZQA9AGEAZABtAGkAbgBpAHMAdAByAGEAdABvAHIALABwAGEAcwBzAHcAbwByAGQAPQBhAGQAbQBpAG4AcABhAHMAcwAiAA=="

解码后,您会看到它是 OP 的原始片段,其中保留了所有参数和双引号。

powershell.exe -EncodedCommand

Accepts a base-64-encoded string version of a command. Use this parameter
to submit commands to Windows PowerShell that require complex quotation
marks or curly braces.

原始命令:

 C:\Program Files\IIS\Microsoft Web Deploy\msdeploy.exe -verb:sync -source:dbfullsql="Data Source=mysource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;" -dest:dbfullsql="Data Source=.\mydestsource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;",computername=10.10.10.10,username=administrator,password=adminpass"

当编码为 Base64 时会变成这样:

QwA6AFwAUAByAG8AZwByAGEAbQAgAEYAaQBsAGUAcwBcAEkASQBTAFwATQBpAGMAcgBvAHMAbwBmAHQAIABXAGUAYgAgAEQAZQBwAGwAbwB5AFwAbQBzAGQAZQBwAGwAbwB5AC4AZQB4AGUAIAAtAHYAZQByAGIAOgBzAHkAbgBjACAALQBzAG8AdQByAGMAZQA6AGQAYgBmAHUAbABsAHMAcQBsAD0AIgBEAGEAdABhACAAUwBvAHUAcgBjAGUAPQBtAHkAcwBvAHUAcgBjAGUAOwBJAG4AdABlAGcAcgBhAHQAZQBkACAAUwBlAGMAdQByAGkAdAB5AD0AZgBhAGwAcwBlADsAVQBzAGUAcgAgAEkARAA9AHMAYQA7AFAAdwBkAD0AcwBhAHAAYQBzAHMAIQA7AEQAYQB0AGEAYgBhAHMAZQA9AG0AeQBkAGIAOwAiACAALQBkAGUAcwB0ADoAZABiAGYAdQBsAGwAcwBxAGwAPQAiAEQAYQB0AGEAIABTAG8AdQByAGMAZQA9AC4AXABtAHkAZABlAHMAdABzAG8AdQByAGMAZQA7AEkAbgB0AGUAZwByAGEAdABlAGQAIABTAGUAYwB1AHIAaQB0AHkAPQBmAGEAbABzAGUAOwBVAHMAZQByACAASQBEAD0AcwBhADsAUAB3AGQAPQBzAGEAcABhAHMAcwAhADsARABhAHQAYQBiAGEAcwBlAD0AbQB5AGQAYgA7ACIALABjAG8AbQBwAHUAdABlAHIAbgBhAG0AZQA9ADEAMAAuADEAMAAuADEAMAAuADEAMAAsAHUAcwBlAHIAbgBhAG0AZQA9AGEAZABtAGkAbgBpAHMAdAByAGEAdABvAHIALABwAGEAcwBzAHcAbwByAGQAPQBhAGQAbQBpAG4AcABhAHMAcwAiAA==

以下是在家复制的方法:

$command = 'C:\Program Files\IIS\Microsoft Web Deploy\msdeploy.exe -verb:sync -source:dbfullsql="Data Source=mysource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;" -dest:dbfullsql="Data Source=.\mydestsource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;",computername=10.10.10.10,username=administrator,password=adminpass"'
$bytes = [System.Text.Encoding]::Unicode.GetBytes($command)
$encodedCommand = [Convert]::ToBase64String($bytes)
$encodedCommand

#  The clip below copies the base64 string to your clipboard for right click and paste.
$encodedCommand | Clip

c
crokusek

对于可执行文件名称,可以使用 new-alias cmdlet 来避免处理空格或需要将可执行文件添加到 $PATH 环境。

PS> new-alias msdeploy "C:\Program Files\IIS\Microsoft Web Deploy\msdeploy.exe"
PS> msdeploy ...

要列出或修改 PS 别名,另请参阅

PS> get-alias
PS> set-alias

来自Jeffery Hicks Aarticle

其他答案解决了这些论点。


Y
Yotam Omer

如果您只需要在当前目录中运行一个文件并且不想拼出整个路径,请使用 Get-Location

& "$(Get-Location)\example.exe" arg1 arg2 arg3

请注意开头的 &。间隔参数应放在引号之后。


d
drizin

我有以下代码在我的笔记本电脑上完美运行:

& $msdeploy `
-source:package="$publishFile" `
-dest:auto,computerName="$server",includeAcls="False",UserName="$username",Password="$password",AuthType="$auth" `
-allowUntrusted  `
-verb:sync  `
-enableRule:DoNotDeleteRule `
-disableLink:AppPoolExtension  `
-disableLink:ContentExtension  `
-disableLink:CertificateExtension  `
-skip:objectName=filePath,absolutePath="^(.*Web\.config|.*Environment\.config)$" `
-setParam:name=`"IIS Web Application Name`",value="$appName"

然后,当我尝试直接在一台服务器上运行它时,我开始收到这些错误 "Unrecognized argument ...etc.... All arguments must begin with "-". "

在尝试了所有可能的解决方法(没有成功)之后,我发现服务器(Windows 2008 R2)上的 Powershell 是 3.0 版本,而我的笔记本电脑是 5.0。 (您可以使用“$PSVersionTable”查看版本)。

upgrading Powershell 到最新版本后,它又开始工作了。


R
Randall Borck

因此,我遇到了类似的问题,并选择以这种方式解决它:

用反引号 (`) 转义引号 (") 字符 用引号 (") 包围新表达式 使用调用运算符 (&),对新字符串发出命令 invoke-expression

示例解决方案:

& { 调用表达式 "C:\Program Files\IIS\Microsoft Web Deploy\msdeploy.exe -verb:sync -source:dbfullsql=`"Data Source=mysource;Integrated Security=false;User ID=sa;Pwd=sapass !;Database=mydb;`" -dest:dbfullsql=`"Data Source=.\mydestsource;Integrated Security=false;User ID=sa;Pwd=sapass!;Database=mydb;`",computername=10.10.10.10,用户名=管理员,密码=adminpass`"" }


C
CBee

要将使用 exiftool.exe 的批处理脚本传输到 powershell 脚本,我不得不将 '-s、"-s 甚至 ${Filename} 提供给命令,另一方面在这些参数中填写变量。

首先:使用 'echochars' 的替代非常棒。它清楚地显示了分组为单个参数的内容以及最终作为下一个参数的内容。

在 powershell 中,它类似于 perl(和 unix 脚本):使用的引号有其含义。

"-s 之间的字符串。字符串将被解释(填充变量)

'-s 之间的字符串。该字符串将不会被解释(或非常有限)

转义字符是 `(反引号)。下一个字符失去了它的特殊含义。可与 unix/linux/perl 上的 \(回击)相媲美。

一些例子:

${ExifArgs} += "-if `"`${FileName} !~ /desktop.ini/i`""
${ExifArgs} += '-dateFormat "%Y\%Y%m\%Y%m%d_%H%M%S"'
${ExifArgs} += ('"' + "-FileName<${NewFotos}\${SourceName}\" + '${DateTimeOriginal}_${ImageWidth}x${ImageHeight}_${Model;s/ //g}_${FileName;s/^.*([0-9]{4})[^0-9].*$/\1/}.%e' + '"')

使用上述方法调用 echoargs 会产生下一个输出(为了隐私,数字被黑客入侵):

Arg 11 is <-if>
Arg 12 is <${FileName} !~ /desktop.ini/i>
Arg 13 is <-dateFormat>
Arg 14 is <%Y\%Y%m\%Y%m%d_%H%M%S>
Arg 15 is <-FileName<D:\Pictures\NewFotos\${DateTimeOriginal}_${ImageWidth}x${ImageHeight}_${Model;s/ //g}_${FileName;s/^.*([0-9]{4})[^0-9].*$/\1/}.%e>

看看第一行如何产生 arg 11 和 12:外部的 "-s 被删除以将整行存储在数组中。由 `-s 引用的内部 "-s 用于将参数保持在一起(而 - if 是前一个参数)

第二个显示 arg 13 和 14:在 '-s 之间使用 "-s。无需使用 `-s 进行转义。

在最后一行(产生 arg 15):单个字符串是通过使用 powershell ()-s 和 +-s 将几个字符串连接到一个字符串来构造的。它使用 " 和 ' 分隔的字符串来让 som ${}-s 由 powershell 填充,一些用于 exiftool。是的,一些 powershell 特殊字符被转换到档案中。