🐢

PowerShell: PowerShell scriptにヘルプを追加する

2021/12/08に公開

はじめに

PowerShell は、ブロックコメントで Get-Help 用のヘルプが書けます。
作成したヘルプは、Get-Help <スクリプトファイル>で表示されます。

コメントベースでヘルプを書く

PowerShell では、'<#','#>'を使うことでブロックコメント~(複数行にわたるコメント)~を書くことができます。
このとき、ヘルプキーワードで始まるコメントを書くと Get-Help でそのコメントが表示されます。

詳しいことは、コメント ベースのヘルプのキーワードを参照してください。
したに主なヘルプキーワードを載せておきます。

キーワード キーワードの説明
.SYNOPSIS スクリプトの簡単な説明、1~3行程度でスクリプトがなにをするかを簡潔に説明します」
.DESCRIPTION スクリプトの詳細な説明、この項は1つのヘルプトピック内で1回だけ使用できます。
.PARAMETER <param> スクリプトを呼び出すときの引数~(パラメータ)~の説明。キーワードに続けて引数を書き、ヘルプ本文で引数の説明を書きます。
.EXAMPLE 実際にスクリプトを使うときの例を、各例ごとに記述します。

ヘルプコメントの書き方

コメントベースのヘルプ、いわゆるヘルプコメントは、次のように書きます。

<#
  .SYNOPSIS
    <簡単なヘルプ>
    ・
    ・
    ・

このように、ブロックコメントヘッダ<#に続けて、空白を開けてヘルプのキーワードを書きます。
そして、その下にヘルプの本文を書きます。これを、各ヘルプのキーワードごとに繰り返します。

作成したヘルプはGet-Helpコマンドレットを使うと表示されます。出力は、次のようになります。

> Get-Help .\help-function.ps1

NAME
    help-function\help-function.ps1

SYNOPSIS
    test -help option script


SYNTAX
   help-function\help-function.ps1 [-h] [-help] [<CommonParameters>]
.
.
.


ヘルプコメントを書くときの注意事項

ヘルプコメントを書くときは、次のようなことに注意する必要があります。
これらに違反した場合は、作成したヘルプは表示されません。最低限の使い方が表示されます。

  • ヘルプコメントブロックには、他のコメントを書かない
    ヘルプコメントの前に普通のコメントを書くと、ヘルプコメントして認識されません。
    ヘッダーコメントなどは、別のコメントとして書く必要があります。

    • ダメな例

      <#
       # <ヘッダコメント>
      
        .SYNOPSIS
          test -help option script
      
      
    • 正しい例

      ##
      # <ヘッダコメント>
      #
      <#
        .SYNOPSIS
          test -help option script
      
      
  • ヘルプはインデントして書く
    ヘルプキーワード~(.SYNOPSISなど)~は、インデントして書く必要があります。インデントしない、すなわち空白を入れずに書くとヘルプとして認識されません。
    ヘルプ本文、つまり.SYNOPSISの次の行のテキストはインデントしなくてもかまいません。
    人が読む場合には、インデントしたおくとヘルプの文章だとわかりやすいでしょう。

    • インデント無し ~(ヘルプは表示されない)~

      <#
        .SYNOPSIS
          test -help option script
      
      
    • 本文インデント無し ~(ヘルプは表示される)~

      <#
        .SYNOPSIS
      test -help option script
      
      
    • インデントあり

      <#
        .SYNOPSIS
          test -help option script
      
      

正しい例の場合は、Get-Help <スクリプト>とするとコメントで記述したヘルプを表示します。

それ以外の場合は、次のような簡単なヘルプを表示します。

> Get-Help ./help-function.ps1
help-function.ps1 [-h] [-help]

まとめ

PowerShell スクリプトでのヘルプの書き方を、ざっと説明してきました。スクリプトに path が通っていれば、Get-Helpでヘルプが見られますし、補完も効きます。

GitHubで編集を提案

Discussion

ログインするとコメントできます