Powershell 将所有详细日志记录导出到 csv 文件

Powershell export all detailed logging to csv file

我继承了一个不起作用的脚本。我需要捕获通常会输出到控制台的所有内容,包括脚本中的成功和错误条目。这只是脚本的一小部分,它只捕获错误。如果能将所有输出输出到文件而不是控制台,我们将不胜感激。

一个例子是Write-Verbose "VERIFYING contact for $($User.WindowsEmailAddress)"

我知道这是在写入控制台,但我需要它来写入在脚本最底部定义的日志。

Catch
                        {Out-File -InputObject "$(Get-Date -Format MM.dd.yyyy-HH:mm:ss);$($WriteMode);ERROR;Target;$($targetUser.Split('@')[1]);$($User.WindowsEmailAddress);Update;;;Error updating user: $($Error[0])" -FilePath $LogFilePath -Append}

我希望这是有道理的。

### UPDATES

    ForEach ($User in $colUpdContact)
    {
        Write-Verbose "VERIFYING contact for $($User.WindowsEmailAddress)"

        #Filter used to find the target contact object(s)
        $strFilter = "WindowsEmailAddress -eq `"$($User.WindowsEmailAddress)`""
        Try
            {$colContacts2 = Invoke-Command -Session $targetSession -ScriptBlock {param ($strFilter) Get-Contact -Filter $strFilter} -ArgumentList $strFilter -ErrorAction Stop}
        Catch
            {Out-File -InputObject "$(Get-Date -Format MM.dd.yyyy-HH:mm:ss);$($WriteMode);ERROR;Target;$($targetUser.Split('@')[1]);$($User.WindowsEmailAddress);Find;;;Error getting contact: $($Error[0])" -FilePath $LogFilePath -Append}
        ForEach ($Contact in $colContacts2)
        {
            #initialize update string and cmd string
            $strUpdateContact = $null
            $updateCmd = $null
            $strWriteBack = $null
            $writeBackCmd = $null

            #Iterate through attributes and append to the strUpdateContact string if the attribute value has changed
            ForEach ($Attrib in $arrAttribs)
            {
                If ($User.$Attrib -ne $Contact.$Attrib)
                {
                    if($ReadOnly){
                        Add-Content -Path $readOnlyFilePath -Value  "   Changing $Attrib"
                        Add-Content -Path $readOnlyFilePath -Value  "       Before: $($Contact.$Attrib)"
                        Add-Content -Path $readOnlyFilePath -Value  "       After: $($User.$Attrib)"
                    }
                    $strUpdateContact += " -$($Attrib) `"$($User.$Attrib)`""
                    Out-File -InputObject "$(Get-Date -Format MM.dd.yyyy-HH:mm:ss);$($WriteMode);CHANGE;Target;$($targetUser.Split('@')[1]);$($User.WindowsEmailAddress);Update;$($Contact.$Attrib);$($User.$Attrib);" -FilePath $LogFilePath -Append
                }
            }

            #Check if LegacyExchangeDN has been written back to User object
            $mailContact = Invoke-Command -Session $targetSession -ScriptBlock {param ($contact) Get-MailContact $($contact.WindowsEmailAddress)} -ArgumentList $Contact -ErrorAction Stop
            $x500 = "X500:$($mailContact.LegacyExchangeDN)"
            $userRec = Invoke-Command -Session $sourceSession -ScriptBlock {param ($User) Get-Recipient $($User.WindowsEmailAddress)} -ArgumentList $User -ErrorAction Stop

            if($UserRec.emailAddresses -notcontains $x500){
                $userName = ($user.UserPrincipalName).Split('@')[0]
                if($userName -eq "")
                {
                    $userName = $user.SamAccountName
                }
                $strWriteBack = "Set-ADUser -Identity $userName -Add @{ProxyAddresses=`"$x500`"} -Server $sourceDC -Credential `$sourceDCCredential"
            }

            #If there is anything to update
            If ($strUpdateContact.Length -gt 0)
            {
                Write-Verbose "Updating attributes for $($User.WindowsEmailAddress)"
                #Prepend the command for the contact being modified
                $strUpdateContact = "Set-Contact $($User.WindowsEmailAddress) " + $strUpdateContact
                If ($ReadOnly)
                    {Add-Content -Path $readOnlyFilePath -Value  $strUpdateContact}
                Else
                {
                    Try
                    {
                        #Create the complete command and invoke it
                        $updateCmd = "Invoke-Command -Session `$targetSession -ScriptBlock {$($strUpdateContact)}"
                        Invoke-Expression $updateCmd -ErrorAction Stop
                    }
                    Catch
                        {Out-File -InputObject "$(Get-Date -Format MM.dd.yyyy-HH:mm:ss);$($WriteMode);ERROR;Target;$($targetUser.Split('@')[1]);$($User.WindowsEmailAddress);Update;;;Error updating contact: $($Error[0])" -FilePath $LogFilePath -Append}
                }
            }
            If ($strWriteBack){
                Write-Verbose "Updating X500 for $($User.WindowsEmailAddress)"
                Out-File -InputObject "$(Get-Date -Format MM.dd.yyyy-HH:mm:ss);$($WriteMode);CHANGE;Target;$($targetUser.Split('@')[1]);$($User.WindowsEmailAddress);Update;;$x500;" -FilePath $LogFilePath -Append
                If($ReadOnly){
                    Add-Content -Path $readOnlyFilePath -Value  $strWriteBack
                }
                else{
                    Try
                    {
                        Invoke-Expression $strWriteBack -ErrorAction Stop
                    }
                    Catch
                        {Out-File -InputObject "$(Get-Date -Format MM.dd.yyyy-HH:mm:ss);$($WriteMode);ERROR;Target;$($targetUser.Split('@')[1]);$($User.WindowsEmailAddress);Update;;;Error updating user: $($Error[0])" -FilePath $LogFilePath -Append}
                }
            }
        }
    }

为什么不使用Start-Transcript将所有信息输出到日志文件中,然后您可以手动复制任何内容?

命令示例:

Start-Transcript -Path $TranscriptOutputFile -Append -Force

#Your script; write-output 'something update';

Stop-Transcript

write-output 命令输出的所有内容都将附加到日志文件中。