Skip to content

Out-VerboseTee

SYNOPSIS

Write to the Verbose stream and a file.

SYNTAX

Out-VerboseTee -Value <Object> [-Path] <String> [-Encoding <Encoding>] [-Append] [<CommonParameters>]

DESCRIPTION

This command is intended to let you see your verbose output and write the verbose messages to a log file. It will only work if the verbose pipeline is enabled, usually when your command is run with -Verbose. This function is designed to be used within your scripts and functions. You either have to hard code a file name or find some other way to define it in your function or control script. You could pass a value as a parameter or set it as a PSDefaultParameterValue.

This command has an alias of Tee-Verbose.

You might use it like this in a script.

Begin {

$log = New-RandomFilename -useTemp -extension log

Write-Detail "Starting $($myinvocation.mycommand)" -Prefix begin | Tee-Verbose $log

Write-Detail "Logging verbose output to $log" -prefix begin | Tee-Verbose -append

Write-Detail "Initializing data array" -Prefix begin | Tee-Verbose $log -append

$data = @()

} #begin

When the command is run with -Verbose you will see the verbose output and it will be saved to the specified log file.

EXAMPLES

Example 1

PS C:\> $VerbosePreference= "continue"
PS C:\> $log = New-CustomFileName ".\VerboseLog_%time.txt"
PS C:\> Write-Detail "This is a verbose log test" | Out-VerboseTee -path $log
PS C:\> Get-Content $log
11/29/2020 08:21:31:0704 [PROCESS] This is a verbose log test
PS C:\> $verbosePreference = "silentlyContinue"

Normally you would use this command inside a function or script, but you can run it from the console if you want to understand how it works.

PARAMETERS

-Append

Append to the specified text file.

Type: System.Management.Automation.SwitchParameter
Parameter Sets: (All)
Aliases:

Required: False
Position: Named
Default value: False
Accept pipeline input: False
Accept wildcard characters: False

-Encoding

Specify a file encoding.

Type: System.Text.Encoding
Parameter Sets: (All)
Aliases:

Required: False
Position: Named
Default value: None
Accept pipeline input: False
Accept wildcard characters: False

-Path

The path for the output file.

Type: System.String
Parameter Sets: (All)
Aliases:

Required: True
Position: 0
Default value: None
Accept pipeline input: False
Accept wildcard characters: False

-Value

The message to be displayed as a verbose message and saved to the file.

Type: System.Object
Parameter Sets: (All)
Aliases:

Required: True
Position: Named
Default value: None
Accept pipeline input: True (ByValue)
Accept wildcard characters: False

CommonParameters

This cmdlet supports the common parameters: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutVariable, -OutBuffer, -PipelineVariable, -Verbose, -WarningAction, and -WarningVariable. For more information, see about_CommonParameters.

INPUTS

System.Object

OUTPUTS

System.Object

NOTES

Learn more about PowerShell: http://jdhitsolutions.com/blog/essential-powershell-resources/

Write-Verbose

Write-Detail

Tee-Object

Back to top