Compartilhar via


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-chave function.

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.

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, FunctionProviderGeneralFAQGlossaryScriptCommandExternalScript, ou . FilterAll 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.
...

Confira também