如何将输出记录到文件

时间:2014-01-20 19:49:11

标签: powershell logging cmdlet

powershell newb here。我在尝试将输出记录到文件时遇到了一些困难。我尝试了两种策略,这两种策略对我都不起作用。第一个是使用Start / Stop-Transcript cmdlet。这在我的本地计算机上进行测试非常有用,但在我部署到工作站的脚本中似乎根本不起作用。

$path1 = Test-Path ($env:ProgramFiles + "\Sophos\Sophos Anti-Virus\SavService.exe")
$path2 = Test-Path (${env:ProgramFiles(x86)} + "\Sophos\Sophos Anti-Virus\SavService.exe")
$shareloc = '\\SERVER1\NETLOGON\SophosPackages\SophosInstall_wFW_Silent.exe'
$logpath = '\\SERVER1\NETLOGON\si_sophos_log.txt'


if (($path1 -eq $true) -or ($path2 -eq $true)) {} ELSE {
& $shareloc
Start-Transcript -Append -Path $logpath | Out-Null
Write-Output ""
Get-Date
Write-Output "Sophos has been installed on `"$env:COMPUTERNAME`""
Write-Output ""
Stop-Transcript
}

我更喜欢这样做的方式是:| Out-File -Append -FilePath $logpath 我认为这将是首选方法,因为它会捕获日志中可能发生的任何错误,如同Start-Transcript一样。但是,当我尝试使用此方法时,我在管道"An empty pipeline element is not allowed."

处收到错误
$path1 = Test-Path ($env:ProgramFiles + "\Sophos\Sophos Anti-Virus\SavService.exe")
$path2 = Test-Path (${env:ProgramFiles(x86)} + "\Sophos\Sophos Anti-Virus\SavService.exe")
$shareloc = '\\SERVER1\NETLOGON\SophosPackages\SophosInstall_wFW_Silent.exe'
$logpath = '\\SERVER1\NETLOGON\si_sophos_log.txt'


if (($path1 -eq $true) -or ($path2 -eq $true)) {} ELSE {
& $shareloc
Write-Output ""
Get-Date
Write-Output "Sophos has been installed on `"$env:COMPUTERNAME`""
Write-Output ""
} | Out-File -Append -FilePath $logpath

提前感谢您的任何帮助!

2 个答案:

答案 0 :(得分:1)

如果您写下以下内容:

if ($true) {Write-Output "titi"} else {Write-Output "toto"} | Out-File -Append c:\temp\titi

您将收到相同的错误,因为管道时不评估if条件。

您可以尝试强制评估它

$(if ($true) {Write-Output "titi"} else {Write-Output "toto"}) | Out-File -Append c:\temp\titi

答案 1 :(得分:0)

如果if条件的计算结果为true,则空的scriptblock会通过管道输出到Out-File,从而导致错误。即以下内容将引发您指定的错误:

if($true) { } else { Write-Output "Something" } | Out-File -Append -FilePath C:\temp\myfile.txt