about_Comment_Based_Help
Descrição breve
Descreve como escrever um comentário com base em conteúdo de ajuda para funções e scripts.
Descrição longa
Você pode escrever conteúdo de ajuda baseado em comentários para funções e scripts através de palavras-chave especiais para comentários de ajuda.
O cmdlet Get-Help exibe ajuda baseada em comentários no mesmo formato em que exibe o conteúdo de ajuda do cmdlet gerado a partir de arquivos XML.
Os usuários podem usar todos os parâmetros de Get-Help
, como Detalhado, Completo, Exemplos e Online, para exibir o conteúdo da ajuda baseada em comentários.
Você também pode escrever arquivos de ajuda baseados em XML para funções e scripts. Para permitir que o Get-Help
cmdlet localize o arquivo de ajuda baseado em XML para uma função ou script, use a .EXTERNALHELP
palavra-chave. Sem essa palavra-chave, o Get-Help
não consegue encontrar conteúdo de ajuda baseado em XML para funções ou scripts.
Este tópico explica como escrever conteúdo de ajuda para funções e scripts. Para obter informações sobre como exibir o conteúdo da ajuda para funções e scripts, consulte Get-Help.
Os cmdlets Update-Help e Save-Help funcionam apenas em arquivos XML. A Ajuda Atualizável não dá suporte ao conteúdo de ajuda baseado em comentários.
Sintaxe para ajuda baseada em comentários
Para criar conteúdo de ajuda baseado em comentário, você pode usar qualquer estilo de comentários: comentários de linha única ou comentários de bloco.
A sintaxe para ajuda baseada em comentários é a seguinte:
# .<help keyword>
# <help content>
ou
<#
.<help keyword>
<help content>
#>
A ajuda baseada em comentários é escrita como uma série de comentários. Você pode digitar um símbolo #
de comentário antes de cada linha de comentários ou pode usar os <#
símbolos e #>
para criar um bloco de comentários. Todas as linhas dentro do bloco de comentários são interpretadas como comentários.
Todas as linhas em um tópico de ajuda baseado em comentários devem ser contíguas. Se um tópico de ajuda baseado em comentários seguir um comentário que não faz parte do tópico de ajuda, deve haver pelo menos uma linha em branco entre a última linha de comentário sem ajuda e o início da ajuda baseada em comentários.
As palavras-chave definem cada seção da ajuda baseada em comentários. Cada palavra-chave de ajuda baseada em comentários é precedida por um ponto .
. As palavras-chave podem aparecer em qualquer ordem. Os nomes de palavra-chave não diferenciam maiúsculas e minúsculas.
Por exemplo, a .Description
palavra-chave precede uma descrição de uma função ou script.
<#
.Description
Get-Function displays the name and syntax of all functions in the session.
#>
O bloco de comentários deve conter pelo menos uma palavra-chave. Algumas das palavras-chave, como .EXAMPLE
, podem aparecer muitas vezes no mesmo bloco de comentários. O conteúdo de ajuda de cada palavra-chave começa na linha após a palavra-chave e pode abranger várias linhas.
Sintaxe para ajuda baseada em comentários em funções
A ajuda baseada em comentários para uma função pode aparecer em um dos três locais:
- No início do corpo da função.
- No final do corpo da função.
- Antes da
function
palavra-chave. Não pode haver mais de uma linha em branco entre a última linha da ajuda da função e a palavra-chavefunction
.
Por exemplo:
function Get-Function {
<#
.<help keyword>
<help content>
#>
# function logic
}
ou
function Get-Function {
# function logic
<#
.<help keyword>
<help content>
#>
}
ou
<#
.<help keyword>
<help content>
#>
function Get-Function { }
Sintaxe para ajuda baseada em comentários em scripts
A ajuda baseada em comentários para um script pode aparecer em um dos dois locais a seguir no script.
No início do arquivo de script. A ajuda do script pode ser precedida no script apenas por comentários e linhas em branco.
Se o primeiro item no corpo do script (após a ajuda) for uma declaração de função, deverá haver pelo menos duas linhas em branco entre o final da ajuda do script e a declaração da função. Caso contrário, a ajuda é interpretada como sendo ajuda para a função, não ajuda para o script.
No final do arquivo de script. No entanto, se o script estiver assinado, coloque Ajuda baseada em comentários no início do arquivo de script. O final do script é ocupado pelo bloco de assinatura.
Por exemplo:
<#
.<help keyword>
<help content>
#>
function Get-Function { }
ou
function Get-Function { }
<#
.<help keyword>
<help content>
#>
Palavras-chave de ajuda baseadas em comentários
A seguir estão palavras-chave de ajuda válidas baseadas em comentários. Essas palavras-chave podem aparecer em qualquer ordem na ajuda baseada em comentários e não diferenciam maiúsculas de minúsculas. As palavras-chave são listadas neste artigo na ordem em que normalmente aparecem em um tópico de ajuda.
.SYNOPSIS
Uma breve descrição da função ou script. Essa palavra-chave pode ser usada apenas uma vez em cada tópico.
.DESCRIPTION
Uma descrição detalhada da função ou script. Essa palavra-chave pode ser usada apenas uma vez em cada tópico.
.PARAMETER
A descrição de um parâmetro. Adicione uma .PARAMETER
palavra-chave para cada parâmetro na sintaxe da função ou do script.
Digite o nome do parâmetro na mesma linha da .PARAMETER
palavra-chave. Digite a descrição do parâmetro nas linhas após a .PARAMETER
palavra-chave. O Windows PowerShell interpreta todo o texto entre a .PARAMETER
linha e a próxima palavra-chave ou o final do bloco de comentários como parte da descrição do parâmetro.
A descrição pode incluir quebras de parágrafo.
.PARAMETER <Parameter-Name>
As palavras-chave Parâmetro podem aparecer em qualquer ordem no bloco de comentários, mas a sintaxe da função ou do script determina a ordem na qual os parâmetros (e suas descrições) aparecem no tópico de ajuda. Para alterar a ordem, altere a sintaxe.
Você também pode especificar uma descrição de parâmetro colocando um comentário na sintaxe da função ou do script imediatamente antes do nome da variável de parâmetro. Para que isso funcione, você também deve ter um bloco de comentários com pelo menos uma palavra-chave.
Se você usar um comentário de sintaxe e uma .PARAMETER
palavra-chave, a descrição associada à .PARAMETER
palavra-chave será usada e o comentário de sintaxe será ignorado.
<#
.SYNOPSIS
Short description here
#>
function Verb-Noun {
[CmdletBinding()]
param (
# This is the same as .Parameter
[string]$Computername
)
# Verb the Noun on the computer
}
.EXAMPLE
Um comando de exemplo que usa a função ou o script, opcionalmente seguido por uma saída de exemplo e uma descrição. Repita essa palavra-chave para cada exemplo.
.INPUTS
Os tipos de objetos .NET que podem ser canalizados para a função ou script. Você também pode incluir uma descrição dos objetos de entrada.
.OUTPUTS
O tipo .NET dos objetos que o cmdlet retorna. Você também pode incluir uma descrição dos objetos retornados.
.NOTES
Informações adicionais sobre a função ou script.
.LINK
O nome de um tópico relacionado. O valor aparece na linha abaixo da palavra-chave ".LINK" e deve ser precedido por um símbolo #
de comentário ou incluído no bloco de comentários.
Repita a .LINK
palavra-chave para cada tópico relacionado.
Esse conteúdo aparece na seção Links Relacionados do tópico de ajuda.
O .Link
conteúdo da palavra-chave também pode incluir um URI (Uniform Resource Identifier) para uma versão online do mesmo tópico de ajuda. A versão online é aberta quando você usa o parâmetro Online de Get-Help
. O URI deve começar com "http" ou "https".
.COMPONENT
O nome da tecnologia ou recurso que a função ou script usa ou ao qual está relacionado. O parâmetro Component of Get-Help
usa esse valor para filtrar os resultados da pesquisa retornados por Get-Help
.
.ROLE
O nome da função de usuário para o tópico de ajuda. O parâmetro Role of Get-Help
usa esse valor para filtrar os resultados da pesquisa retornados por Get-Help
.
.FUNCTIONALITY
As palavras-chave que descrevem o uso pretendido da função. O parâmetro Functionality de Get-Help
usa esse valor para filtrar os resultados da pesquisa retornados por Get-Help
.
.FORWARDHELPTARGETNAME
Redireciona para o tópico de ajuda do comando especificado. Você pode redirecionar usuários para qualquer tópico de ajuda, incluindo conteúdo de ajuda para uma função, script, cmdlet ou provedor.
# .FORWARDHELPTARGETNAME <Command-Name>
.FORWARDHELPCATEGORY
Especifica a categoria de ajuda do item em .ForwardHelpTargetName
. Os valores válidos são Alias
, Cmdlet
, HelpFile
, Function
Provider
General
FAQ
Glossary
ScriptCommand
ExternalScript
, ou . Filter
All
Use essa palavra-chave para evitar conflitos quando houver comandos com o mesmo nome.
# .FORWARDHELPCATEGORY <Category>
.REMOTEHELPRUNSPACE
Especifica uma sessão que contém o tópico de ajuda. Insira uma variável que contenha um objeto PSSession . Essa palavra-chave é usada pelo cmdlet Export-PSSession para localizar o conteúdo de ajuda para os comandos exportados.
# .REMOTEHELPRUNSPACE <PSSession-variable>
.EXTERNALHELP
Especifica um arquivo de ajuda baseado em XML para o script ou função.
# .EXTERNALHELP <XML Help File>
A .EXTERNALHELP
palavra-chave é necessária quando uma função ou script é documentado em arquivos XML. Sem essa palavra-chave, o Get-Help
não é possível encontrar o arquivo de ajuda baseado em XML para a função ou o script.
A .EXTERNALHELP
palavra-chave tem precedência sobre outras palavras-chave de ajuda baseadas em comentários. Se .EXTERNALHELP
estiver presente, o Get-Help
não exibirá ajuda baseada em comentários, mesmo que não encontre um tópico de ajuda que corresponda ao valor da palavra-chave .EXTERNALHELP
.
Se a função for exportada por um módulo, defina o .EXTERNALHELP
valor da palavra-chave como um nome de arquivo sem um caminho.
Get-Help
procura o nome do arquivo especificado em um subdiretório específico do idioma do diretório do módulo. Não há requisitos para o nome do arquivo de ajuda baseado em XML para uma função, mas uma prática recomendada é usar o seguinte formato:
<ScriptModule.psm1>-help.xml
Se a função não estiver incluída em um módulo, inclua um caminho para o arquivo de ajuda baseado em XML. Se o valor incluir um caminho e o caminho contiver subdiretórios específicos da cultura da interface do usuário, Get-Help
o pesquisará os subdiretórios recursivamente por um arquivo XML com o nome do script ou da função de acordo com os padrões de fallback de linguagem estabelecidos para Windows, assim como em um diretório de módulo.
Para obter mais informações sobre o formato de arquivo de ajuda baseado em XML da ajuda do cmdlet, consulte Como escrever a ajuda do cmdlet.
Conteúdo gerado automaticamente
O nome, a sintaxe, a lista de parâmetros, a tabela de atributos de parâmetros, os parâmetros comuns e os Get-Help
comentários são gerados automaticamente pelo cmdlet.
Nome
A seção Nome de um tópico de ajuda de função é obtida do nome da função na sintaxe da função. O tópico de ajuda Nome de um script é obtido do nome do arquivo de script. Para alterar o nome ou sua capitalização, altere a sintaxe da função ou o nome do arquivo de script.
Sintaxe
A seção Sintaxe do tópico de ajuda é gerada a partir da sintaxe da função ou do script. Para adicionar detalhes à sintaxe do tópico de ajuda, como o tipo .NET de um parâmetro, adicione os detalhes à sintaxe. Se você não especificar um tipo de parâmetro, o tipo Object será inserido como o valor padrão.
Lista de parâmetros
A lista de parâmetros no tópico de ajuda é gerada a partir da sintaxe da função ou do script e das descrições que você adiciona usando a .Parameter
palavra-chave. Os parâmetros da função aparecem na seção Parâmetros do tópico da ajuda na mesma ordem em que aparecem na sintaxe da função ou do script.
A ortografia e a capitalização dos nomes dos parâmetros também são retiradas da sintaxe. Ele não é afetado pelo nome do parâmetro especificado pela palavra-chave .Parameter
.
Parâmetros comuns
Os parâmetros comuns são adicionados à sintaxe e à lista de parâmetros do tópico de ajuda, mesmo que não tenham efeito. Para obter mais informações sobre os parâmetros comuns, consulte about_CommonParameters.
Tabela de atributos de parâmetros
Get-Help
gera a tabela de atributos de parâmetro que aparece quando você usa o parâmetro Full ou Parameter de Get-Help
. O valor dos atributos de valor Required, Position e Default é obtido da sintaxe da função ou do script.
Valores padrão e um valor para Aceitar caracteres curinga não aparecem na tabela de atributos de parâmetro mesmo quando são definidos na função ou script. Para ajudar os usuários, forneça essas informações na descrição do parâmetro.
Comentários
A seção Comentários do tópico de ajuda é gerada automaticamente a partir do nome da função ou do script. Não é possível alterar ou afetar seu conteúdo.
Exemplos
Ajuda baseada em comentários para uma função
A função de exemplo a seguir inclui ajuda baseada em comentários:
function Add-Extension
{
param ([string]$Name,[string]$Extension = "txt")
$name = $name + "." + $extension
$name
<#
.SYNOPSIS
Adds a file name extension to a supplied name.
.DESCRIPTION
Adds a file name extension to a supplied name.
Takes any strings for the file name or extension.
.PARAMETER Name
Specifies the file name.
.PARAMETER Extension
Specifies the extension. "Txt" is the default.
.INPUTS
None. You can't pipe objects to Add-Extension.
.OUTPUTS
System.String. Add-Extension returns a string with the extension
or file name.
.EXAMPLE
PS> extension -name "File"
File.txt
.EXAMPLE
PS> extension -name "File" -extension "doc"
File.doc
.EXAMPLE
PS> extension "File" "doc"
File.doc
.LINK
http://www.fabrikam.com/extension.html
.LINK
Set-Item
#>
}
Os resultados são os seguintes:
Get-Help -Name "Add-Extension" -Full
NAME
Add-Extension
SYNOPSIS
Adds a file name extension to a supplied name.
SYNTAX
Add-Extension [[-Name] <String>] [[-Extension] <String>]
[<CommonParameters>]
DESCRIPTION
Adds a file name extension to a supplied name. Takes any strings for the
file name or extension.
PARAMETERS
-Name
Specifies the file name.
Required? false
Position? 0
Default value
Accept pipeline input? false
Accept wildcard characters?
-Extension
Specifies the extension. "Txt" is the default.
Required? false
Position? 1
Default value
Accept pipeline input? false
Accept wildcard characters?
<CommonParameters>
This cmdlet supports the common parameters: -Verbose, -Debug,
-ErrorAction, -ErrorVariable, -WarningAction, -WarningVariable,
-OutBuffer and -OutVariable. For more information, type
"get-help about_commonparameters".
INPUTS
None. You can't pipe objects to Add-Extension.
OUTPUTS
System.String. Add-Extension returns a string with the extension or
file name.
Example 1
PS> extension -name "File"
File.txt
Example 2
PS> extension -name "File" -extension "doc"
File.doc
Example 3
PS> extension "File" "doc"
File.doc
RELATED LINKS
http://www.fabrikam.com/extension.html
Set-Item
Descrições de parâmetros na sintaxe da função
Este exemplo é o mesmo que o anterior, exceto que as descrições dos parâmetros são inseridas na sintaxe da função. Esse formato é mais útil quando as descrições são breves.
function Add-Extension
{
param
(
[string]
#Specifies the file name.
$name,
[string]
#Specifies the file name extension. "Txt" is the default.
$extension = "txt"
)
$name = $name + "." + $extension
$name
<#
.SYNOPSIS
Adds a file name extension to a supplied name.
.DESCRIPTION
Adds a file name extension to a supplied name. Takes any strings for the
file name or extension.
.INPUTS
None. You can't pipe objects to Add-Extension.
.OUTPUTS
System.String. Add-Extension returns a string with the extension or
file name.
.EXAMPLE
PS> extension -name "File"
File.txt
.EXAMPLE
PS> extension -name "File" -extension "doc"
File.doc
.EXAMPLE
PS> extension "File" "doc"
File.doc
.LINK
http://www.fabrikam.com/extension.html
.LINK
Set-Item
#>
}
Ajuda baseada em comentários para um script
O script de exemplo a seguir inclui ajuda baseada em comentários. Observe as linhas em branco entre o fechamento #>
e a Param
instrução. Em um script que não tenha uma instrução Param
, deve haver pelo menos duas linhas em branco entre o comentário final no tópico de ajuda e a primeira declaração de função. Sem essas linhas em branco, Get-Help
associa o tópico de ajuda à função, não ao script.
<#
.SYNOPSIS
Performs monthly data updates.
.DESCRIPTION
The Update-Month.ps1 script updates the registry with new data generated
during the past month and generates a report.
.PARAMETER InputPath
Specifies the path to the CSV-based input file.
.PARAMETER OutputPath
Specifies the name and path for the CSV-based output file. By default,
MonthlyUpdates.ps1 generates a name from the date and time it runs, and
saves the output in the local directory.
.INPUTS
None. You can't pipe objects to Update-Month.ps1.
.OUTPUTS
None. Update-Month.ps1 doesn't generate any output.
.EXAMPLE
PS> .\Update-Month.ps1
.EXAMPLE
PS> .\Update-Month.ps1 -inputpath C:\Data\January.csv
.EXAMPLE
PS> .\Update-Month.ps1 -inputpath C:\Data\January.csv -outputPath `
C:\Reports\2009\January.csv
#>
param ([string]$InputPath, [string]$OutPutPath)
function Get-Data { }
...
O comando a seguir obtém a ajuda do script. Como o script não está em um diretório listado na variável de ambiente $env:Path
, o comando Get-Help
que obtém a ajuda do script deve especificar o caminho do script.
Get-Help -Name .\update-month.ps1 -Full
# NAME
C:\ps-test\Update-Month.ps1
# SYNOPSIS
Performs monthly data updates.
# SYNTAX
C:\ps-test\Update-Month.ps1 [-InputPath] <String> [[-OutputPath]
<String>] [<CommonParameters>]
# DESCRIPTION
The Update-Month.ps1 script updates the registry with new data
generated during the past month and generates a report.
# PARAMETERS
-InputPath
Specifies the path to the CSV-based input file.
Required? true
Position? 0
Default value
Accept pipeline input? false
Accept wildcard characters?
-OutputPath
Specifies the name and path for the CSV-based output file. By
default, MonthlyUpdates.ps1 generates a name from the date
and time it runs, and saves the output in the local directory.
Required? false
Position? 1
Default value
Accept pipeline input? false
Accept wildcard characters?
<CommonParameters>
This cmdlet supports the common parameters: -Verbose, -Debug,
-ErrorAction, -ErrorVariable, -WarningAction, -WarningVariable,
-OutBuffer and -OutVariable. For more information, type,
"get-help about_commonparameters".
# INPUTS
None. You can't pipe objects to Update-Month.ps1.
# OUTPUTS
None. Update-Month.ps1 doesn't generate any output.
Example 1
PS> .\Update-Month.ps1
Example 2
PS> .\Update-Month.ps1 -inputpath C:\Data\January.csv
Example 3
PS> .\Update-Month.ps1 -inputpath C:\Data\January.csv -outputPath
C:\Reports\2009\January.csv
# RELATED LINKS
Redirecionando para um arquivo XML
É possível escrever conteúdo de ajuda baseado em XML para funções e scripts. Embora a ajuda baseada em comentários seja mais fácil de implementar, a ajuda baseada em XML é necessária para a Ajuda Atualizável e para fornecer conteúdo de ajuda em vários idiomas.
O exemplo a seguir mostra as primeiras linhas do script Update-Month.ps1.
O script usa a .EXTERNALHELP
palavra-chave para especificar o caminho para um tópico de ajuda baseado em XML para o script.
Observe que o .EXTERNALHELP
valor da palavra-chave aparece na mesma linha que a palavra-chave. Qualquer outra colocação é ineficaz.
# .EXTERNALHELP C:\MyScripts\Update-Month-Help.xml
param ([string]$InputPath, [string]$OutPutPath)
function Get-Data { }
...
Os exemplos a seguir mostram três posicionamentos válidos da .EXTERNALHELP
palavra-chave em uma função.
function Add-Extension {
# .EXTERNALHELP C:\ps-test\Add-Extension.xml
param ([string] $name, [string]$extension = "txt")
$name = $name + "." + $extension
$name
}
function Add-Extension {
param ([string] $name, [string]$extension = "txt")
$name = $name + "." + $extension
$name
# .EXTERNALHELP C:\ps-test\Add-Extension.xml
}
# .EXTERNALHELP C:\ps-test\Add-Extension.xml
function Add-Extension {
param ([string] $name, [string]$extension = "txt")
$name = $name + "." + $extension
$name
}
Redirecionando para um tópico de ajuda diferente
O código a seguir é um trecho do início da função de ajuda interna no PowerShell, que exibe uma tela de texto de ajuda por vez.
Como o tópico de ajuda do Get-Help
cmdlet descreve a função de ajuda, a função de ajuda usa as .ForwardHelpTargetName
palavras-chave e .ForwardHelpCategory
para redirecionar o usuário para o tópico de ajuda do Get-Help
cmdlet.
function help {
<#
.FORWARDHELPTARGETNAME Get-Help
.FORWARDHELPCATEGORY Cmdlet
#>
[CmdletBinding(DefaultParameterSetName='AllUsersView')]
param(
[Parameter(Position=0, ValueFromPipelineByPropertyName=$true)]
[System.String]
${Name},
...
O comando a seguir usa esse recurso:
Get-Help -Name help
NAME
Get-Help
SYNOPSIS
Displays information about PowerShell cmdlets and concepts.
...