Skip to content

Latest commit

 

History

History
148 lines (98 loc) · 3.3 KB

Out-VerboseTee.md

File metadata and controls

148 lines (98 loc) · 3.3 KB
external help file Module Name online version schema
PSScriptTools-help.xml
PSScriptTools
2.0.0

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: SwitchParameter
Parameter Sets: (All)
Aliases:

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

-Encoding

Specify a file encoding.

Type: 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: 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: 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 (http://go.microsoft.com/fwlink/?LinkID=113216).

INPUTS

System.Object

OUTPUTS

System.Object

NOTES

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

RELATED LINKS

Write-Verbose

Write-Detail

Tee-Object