我编写了一个powershell脚本来读取文本文件中的数据,然后使用VBoxManage克隆虚拟机。但是,它可以报告此错误。
[string]$vmPath = "C:\Users\someuser\VirtualBox VMs\"
[string]$vmName="QuestionMark"
[string]$vBoxClonevdi = "clonehd"
[string]$vBoxVMName = Get-Content -Path "C:\Users\someuser\VirtualBox VMs\log.txt"
[string]$invokeCommand
[string]$filetype=".vdi"
[string]$vBoxManagewithQuotes= "`"C:\Program Files\Oracle\VirtualBox\VBoxManage.exe`""
if(Test-Path ("C:\Users\someuser\VirtualBox VMs\log.txt")){
[int]$ConvertNum = -1
[int]::TryParse($vBoxVMName.Substring(16), [ref]$ConvertNum)
Write-Output ("Version Number: " + $ConvertNum)
$ConvertAfter = $ConvertNum + 1
Write-Output ("New Version: " + $ConvertAfter)
$vmOut = $vmPath+$vmName+$ConvertAfter+$filetype
$vmToClone=($vmPath+$vmName+$ConvertNum+$fileType)
$write= ($vmName + $ConvertAfter)
}
if(Test-Path ("C:\Users\someuser\cloneVM.bat")){
cmd.exe /c "C:\Users\someuser\cloneVM.bat" $vmName $ConvertAfter
}
错误:
cmd.exe : 0%...10%...20%...30%...40%...50%...60%...70%...80%...90%...100%
At C:\Users\someuser\clonevdi.ps1:28 char:6
+ cmd.exe /c "C:\Users\someuser\cloneVM.bat" $vmName $ConvertAfter
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : NotSpecified: (0%...10%...20%....0%...90%...100%:String) [], RemoteException
+ FullyQualifiedErrorId : NativeCommandError
我不确定这个错误意味着什么。这是什么意思?以及如何修复它?
答案 0 :(得分:0)
非常确定您所看到的是cloneVM.bat
将数据发送到错误流,而PowerShell正在报告错误。我可以使用以下bat文件
'GAME OVER MAN! GAME OVER' 1>&2
从PowerShell调用该bat文件
cmd.exe /c C:\temp\test.bat
这会在PowerShell中触发以下错误
cmd.exe : 'GAME OVER MAN! GAME OVER'
At line:1 char:1
+ cmd.exe /c C:\temp\test.bat
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : NotSpecified: ('GAME OVER MAN! GAME OVER' :String) [], RemoteException
+ FullyQualifiedErrorId : NativeCommandError
处理此问题的一种方法是将错误发送到输出流,然后将其捕获到变量中。如果您需要cloneVM.bat
的其他输出,这将是首选方法。您可以使用about_Redirection
$return = cmd.exe /c C:\temp\test.bat 2>&1
如果您要查看cloneVM.bat
我会冒昧地猜测您会找到一些2>&1