如何编写 PowerShell 模块清单

编写 PowerShell 模块后,可以添加一个可选模块清单,其中包含有关该模块的信息。 例如,可以描述作者、指定模块(如嵌套模块)中的文件、运行脚本来自定义用户的环境、加载类型和格式文件、定义系统要求,以及限制模块导出的成员。

创建模块清单

模块清单 是一个 PowerShell 数据文件(.psd1),用于描述模块的内容并确定模块的处理方式。 清单文件是包含键和值的哈希表的文本文件。 将清单文件链接到模块,方法是将清单命名为与模块相同的清单,并将清单存储在模块的根目录中。

对于仅包含单个 .psm1 或二进制程序集的简单模块,模块清单是可选的。 但是,建议尽可能使用模块清单,因为它们有助于组织代码和维护版本控制信息。 并且,需要模块清单才能导出安装在 全局程序集缓存中的程序集。 支持可更新帮助功能的模块还需要模块清单。 可更新帮助使用模块清单中的 HelpInfoUri 键查找包含模块更新帮助文件位置的帮助信息(HelpInfo XML)文件。 有关可更新帮助的详细信息,请参阅 支持可更新帮助

创建和使用模块清单

  1. 创建模块清单的最佳做法是使用 New-ModuleManifest cmdlet。 可以使用参数指定清单的一个或多个默认键和值。 唯一的要求是命名文件。 New-ModuleManifest 使用指定的值创建模块清单,并包括剩余的键及其默认值。 如果需要创建多个模块,请使用 New-ModuleManifest 创建可针对不同模块修改的模块清单模板。 有关默认模块清单的示例,请参阅 示例模块清单

    New-ModuleManifest -Path C:\myModuleName.psd1 -ModuleVersion "2.0" -Author "YourNameHere"

    另一种方法是使用所需的最少信息(ModuleVersion)手动创建模块清单的哈希表。 保存与模块同名的文件,并使用 .psd1 文件扩展名。 然后,可以编辑该文件并添加相应的键和值。

  2. 在清单文件中添加所需的任何其他元素。

    若要编辑清单文件,请使用你喜欢的任何文本编辑器。 但是,清单文件是一个包含代码的脚本文件,因此你可能希望在脚本或开发环境(如 Visual Studio Code)中对其进行编辑。 清单文件的所有元素都是可选的,ModuleVersion 编号除外。

    有关模块清单中包含的键和值的说明,请参阅 模块清单元素 表。 有关详细信息,请参阅 New-ModuleManifest cmdlet 中的参数说明。

  3. 若要解决基本模块清单元素可能未涵盖的任何方案,可以选择向模块清单添加其他代码。

    出于安全问题,PowerShell 仅在模块清单文件中运行一小部分可用作。 通常,可以使用 if 语句、算术和比较运算符以及基本的 PowerShell 数据类型。

  4. 创建模块清单后,可以对其进行测试,以确认清单中描述的任何路径都正确。 若要测试模块清单,请使用 Test-ModuleManifest

    Test-ModuleManifest myModuleName.psd1

  5. 请确保模块清单位于包含模块的目录的顶层。

    将模块复制到系统并导入它时,PowerShell 使用模块清单导入模块。

  6. (可选)可以通过通过点溯源清单本身来直接测试模块清单,并调用 Import-Module

    Import-Module .\myModuleName.psd1

模块清单元素

下表描述了可以在模块清单中包含的元素。 有关详细信息,请参阅 about_Module_Manifests

元素 违约 说明
RootModule
类型:String
<empty string> 编写与此清单关联的模块或二进制模块文件脚本。 以前版本的 PowerShell 称为 ModuleToProcess
根模块的可能类型可以为空,这会创建 清单 模块、脚本模块的名称(.psm1),或二进制模块的名称(.exe.dll)。 在此元素中放置模块清单(.psd1)或脚本文件(.ps1)的名称会导致错误。
示例:RootModule = 'ScriptModule.psm1'
ModuleVersion
类型:Version
'0.0.1' 此模块的版本号。 如果未指定值,则 New-ModuleManifest 使用默认值。 字符串必须能够转换为类型 Version,例如 #.#.#.#Import-Module 加载它在与名称匹配的 $PSModulePath 上找到的第一个模块,并且至少具有与 ModuleVersion相同的 MinimumVersion 参数。 若要导入特定版本,请使用 Import-Module cmdlet 的 RequiredVersion 参数。
示例:ModuleVersion = '1.0'
GUID
类型:GUID
'<GUID>' 用于唯一标识此模块的 ID。 如果未指定值,New-ModuleManifest 自动生成值。 当前无法通过 GUID 导入模块。
示例:GUID = 'cfc45206-1e49-459d-a8ad-5b571ef94857'
作者
类型:String
'<Current user>' 此模块的作者。 如果未指定值,则 New-ModuleManifest 使用当前用户。
示例:Author = 'AuthorNameHere'
CompanyName
类型:String
'Unknown' 本模块的公司或供应商。 如果未指定值,则 New-ModuleManifest 使用默认值。
示例:CompanyName = 'Fabrikam'
版权
类型:String
'(c) <Author>. All rights reserved.' 本模块的版权声明。 如果未指定值,New-ModuleManifest 将默认值与当前用户一起使用作为 <Author>。 若要指定作者,请使用 Author 参数。
示例:Copyright = '2019 AuthorName. All rights reserved.'
说明
类型:String
<empty string> 此模块提供的功能的说明。
示例:Description = 'This is the module's description.'
PowerShellVersion
类型:Version
<empty string> 此模块所需的 PowerShell 引擎的最低版本。 有效值为 1.0、2.0、3.0、4.0、5.0、5.1、6.0、6.1、6.2、7.0 和 7.1。
示例:PowerShellVersion = '5.0'
PowerShellHostName
类型:String
<empty string> 此模块所需的 PowerShell 主机的名称。 此名称由 PowerShell 提供。 若要查找主机程序的名称,请在程序中键入:$Host.Name
示例:PowerShellHostName = 'ConsoleHost'
PowerShellHostVersion
类型:Version
<empty string> 此模块所需的 PowerShell 主机的最低版本。
示例:PowerShellHostVersion = '2.0'
DotNetFrameworkVersion
类型:Version
<empty string> 此模块所需的最低版本 Microsoft .NET Framework。 此先决条件仅适用于 PowerShell Desktop 版本,例如 Windows PowerShell 5.1,仅适用于低于 4.5 的 .NET Framework 版本。
示例:DotNetFrameworkVersion = '3.5'
CLRVersion
类型:Version
<empty string> 本模块所需的公共语言运行时(CLR)的最低版本。 此先决条件仅适用于 PowerShell Desktop 版本,例如 Windows PowerShell 5.1,仅适用于低于 4.5 的 .NET Framework 版本。
示例:CLRVersion = '3.5'
ProcessorArchitecture
类型:ProcessorArchitecture
<empty string> 此模块所需的处理器体系结构(无、X86、Amd64)。 有效值为 x86、AMD64、Arm、IA64、MSIL 和 None(未知或未指定)。
示例:ProcessorArchitecture = 'x86'
RequiredModules
类型:Object[]
@() 导入此模块之前,必须导入到全局环境中的模块。 这会加载列出的任何模块,除非它们已加载。 例如,某些模块可能已由其他模块加载。 可以使用 RequiredVersion 而不是 ModuleVersion指定要加载的特定版本。 使用 ModuleVersion 时,它将加载可用最新版本,并且至少包含指定的版本。 可以在参数值中合并字符串和哈希表。
示例:RequiredModules = @("MyModule", @{ModuleName="MyDependentModule"; ModuleVersion="2.0"; GUID="cfc45206-1e49-459d-a8ad-5b571ef94857"})
示例:RequiredModules = @("MyModule", @{ModuleName="MyDependentModule"; RequiredVersion="1.5"; GUID="cfc45206-1e49-459d-a8ad-5b571ef94857"})
RequiredAssemblies
类型:String[]
@() 导入此模块之前必须加载的程序集。 指定模块所需的程序集(.dll)文件名。
PowerShell 在更新类型或格式、导入嵌套模块或导入 RootModule 键值中指定的模块文件之前加载指定的程序集。 使用此参数列出模块所需的所有程序集。
示例:RequiredAssemblies = @("assembly1.dll", "assembly2.dll", "assembly3.dll")
ScriptsToProcess
类型:String[]
@() 导入模块时,在调用方会话状态中运行的脚本(.ps1) 文件。 这可能是全局会话状态,或者,对于嵌套模块,另一个模块的会话状态。 可以使用这些脚本来准备环境,就像使用登录脚本一样。
这些脚本在加载清单中列出的任何模块之前运行。
示例:ScriptsToProcess = @("script1.ps1", "script2.ps1", "script3.ps1")
TypesToProcess
类型:String[]
@() 导入此模块时要加载的类型文件(.ps1xml)。
示例:TypesToProcess = @("type1.ps1xml", "type2.ps1xml", "type3.ps1xml")
FormatsToProcess
类型:String[]
@() 导入此模块时要加载的格式化文件(.ps1xml)。
示例:FormatsToProcess = @("format1.ps1xml", "format2.ps1xml", "format3.ps1xml")
NestedModules
类型:Object[]
@() 要作为 RootModule 中指定的模块的嵌套模块导入的模块(别名:ModuleToProcess)。
向此元素添加模块名称类似于从脚本或程序集代码中调用 Import-Module。 使用清单文件的主要区别在于,更容易看到正在加载的内容。 而且,如果模块无法加载,则尚未加载实际模块。
除了其他模块,还可以在此处加载脚本(.ps1)文件。 这些文件将在根模块的上下文中执行。 这相当于在根模块中点溯脚本。
示例:NestedModules = @("script.ps1", @{ModuleName="MyModule"; ModuleVersion="1.0.0.0"; GUID="50cdb55f-5ab7-489f-9e94-4ec21ff51e59"})
FunctionsToExport
类型:String[]
@() 指定要从此模块导出的函数,为获得最佳性能,请不要使用通配符,也不删除条目,如果没有要导出的函数,请使用空数组。 默认情况下,不会导出任何函数。 可以使用此密钥列出模块导出的函数。
模块将函数导出到调用方会话状态。 调用方会话状态可以是全局会话状态,或者对于嵌套模块,另一个模块的会话状态。 链接嵌套模块时,嵌套模块导出的所有函数都将导出到全局会话状态,除非链中的模块通过使用 FunctionsToExport 键来限制函数。
如果清单导出函数的别名,则此键可以删除别名列在 AliasesToExport 键中的函数,但此键无法向列表中添加函数别名。
示例:FunctionsToExport = @("function1", "function2", "function3")
CmdletsToExport
类型:String[]
@() 指定要从此模块导出的 cmdlet,为获得最佳性能,请不要使用通配符,也不删除条目,如果没有要导出的 cmdlet,请使用空数组。 默认情况下,不会导出任何 cmdlet。 可以使用此密钥列出模块导出的 cmdlet。
调用方会话状态可以是全局会话状态,或者对于嵌套模块,另一个模块的会话状态。 链接嵌套模块时,嵌套模块导出的所有 cmdlet 都将导出到全局会话状态,除非链中的模块通过使用 CmdletsToExport 键来限制 cmdlet。
如果清单导出 cmdlet 的别名,则此密钥可以删除其别名列在 AliasesToExport 键中的 cmdlet,但此键无法向列表中添加 cmdlet 别名。
示例:CmdletsToExport = @("Get-MyCmdlet", "Set-MyCmdlet", "Test-MyCmdlet")
VariablesToExport
类型:String[]
'*' 指定模块导出到调用方会话状态的变量。 允许使用通配符。 默认情况下,导出所有变量('*')。 可以使用此密钥来限制模块导出的变量。
调用方会话状态可以是全局会话状态,或者对于嵌套模块,另一个模块的会话状态。 链接嵌套模块时,嵌套模块导出的所有变量都将导出到全局会话状态,除非链中的模块通过使用 VariablesToExport 键来限制变量。
如果清单还导出变量的别名,则此键可以删除别名列在 AliasesToExport 键中的变量,但此键无法向列表中添加变量别名。
示例:VariablesToExport = @('$MyVariable1', '$MyVariable2', '$MyVariable3')
AliasesToExport
类型:String[]
@() 指定要从此模块导出的别名,为获得最佳性能,请不要使用通配符,也不删除条目,如果没有要导出的别名,请使用空数组。 默认情况下,不会导出任何别名。 可以使用此密钥列出模块导出的别名。
模块将别名导出到调用方会话状态。 调用方会话状态可以是全局会话状态,或者对于嵌套模块,另一个模块的会话状态。 链接嵌套模块时,嵌套模块导出的所有别名最终将导出到全局会话状态,除非链中的模块通过使用 AliasesToExport 键来限制别名。
示例:AliasesToExport = @("MyAlias1", "MyAlias2", "MyAlias3")
DscResourcesToExport
类型:String[]
@() 指定要从此模块导出的 DSC 资源。 允许使用通配符。
示例:DscResourcesToExport = @("DscResource1", "DscResource2", "DscResource3")
ModuleList
类型:Object[]
@() 指定使用此模块打包的所有模块。 这些模块可以按名称输入,使用逗号分隔的字符串,也可以作为具有 ModuleName 的哈希表,以及 GUID 键。 哈希表还可以具有可选的 moduleVersion ModuleList 密钥旨在充当模块清单。 这些模块不会自动处理。
示例:ModuleList = @("SampleModule", "MyModule", @{ModuleName="MyModule"; ModuleVersion="1.0.0.0"; GUID="50cdb55f-5ab7-489f-9e94-4ec21ff51e59"})
FileList
类型:String[]
@() 使用此模块打包的所有文件的列表。 与 ModuleList一样,FileList 是清单列表,否则不会处理。
示例:FileList = @("File1", "File2", "File3")
PrivateData
类型:Object
@{...} 指定需要传递给 RootModule(别名:ModuleToProcess)密钥指定的根模块的任何专用数据。 PrivateData 是一个哈希表,其中包含多个元素:TagsLicenseUriProjectURIIconUriReleaseNotes预发行版RequireLicenseAcceptanceExternalModuleDependencies
标记
类型:String[]
@() 标记有助于联机库中的模块发现。
示例:Tags = "PackageManagement", "PowerShell", "Manifest"
LicenseUri
类型:Uri
<empty string> 此模块许可证的 URL。
示例:LicenseUri = 'https://www.contoso.com/license'
ProjectUri
类型:Uri
<empty string> 此项目的主网站的 URL。
示例:ProjectUri = 'https://www.contoso.com/project'
IconUri
类型:Uri
<empty string> 表示此模块的图标的 URL。
示例:IconUri = 'https://www.contoso.com/icons/icon.png'
ReleaseNotes
类型:String
<empty string> 指定模块的发行说明。
示例:ReleaseNotes = 'The release notes provide information about the module.
预发布
类型:String
<empty string> 此参数已在 PowerShellGet 1.6.6 中添加。 PreRelease 字符串,该字符串将模块标识为联机库中的预发行版。
示例:PreRelease = 'alpha'
RequireLicenseAcceptance
类型:Boolean
$false 此参数已添加到 PowerShellGet 1.5 中。 此标志指示模块是否要求用户明确同意安装、更新或保存。
示例:RequireLicenseAcceptance = $false
ExternalModuleDependencies
类型:String[]
@() 此参数已在 PowerShellGet v2 中添加。 此模块所依赖的外部模块的列表。
示例:ExternalModuleDependencies = @("ExtModule1", "ExtModule2", "ExtModule3")。 此列表仅供信息化。 与 RequiredModules 不同,它不用于强制实施依赖项。
HelpInfoURI
类型:String
<empty string> 此模块的 HelpInfo URI。
示例:HelpInfoURI = 'https://www.contoso.com/help'
DefaultCommandPrefix
类型:String
<empty string> 从此模块导出的命令的默认前缀。 使用 Import-Module -Prefix替代默认前缀。
示例:DefaultCommandPrefix = 'My'

示例模块清单

以下示例模块清单是在 PowerShell 7 中使用 New-ModuleManifest 创建的,其中包含默认键和值。

#
# Module manifest for module 'SampleModuleManifest'
#
# Generated by: User01
#
# Generated on: 10/15/2019
#

@{

# Script module or binary module file associated with this manifest.
# RootModule = ''

# Version number of this module.
ModuleVersion = '0.0.1'

# Supported PSEditions
# CompatiblePSEditions = @()

# ID used to uniquely identify this module
GUID = 'b632e90c-df3d-4340-9f6c-3b832646bf87'

# Author of this module
Author = 'User01'

# Company or vendor of this module
CompanyName = 'Unknown'

# Copyright statement for this module
Copyright = '(c) User01. All rights reserved.'

# Description of the functionality provided by this module
# Description = ''

# Minimum version of the PowerShell engine required by this module
# PowerShellVersion = ''

# Name of the PowerShell host required by this module
# PowerShellHostName = ''

# Minimum version of the PowerShell host required by this module
# PowerShellHostVersion = ''

# Minimum version of Microsoft .NET Framework required by this module. This prerequisite is valid for the PowerShell Desktop edition only.
# DotNetFrameworkVersion = ''

# Minimum version of the common language runtime (CLR) required by this module. This prerequisite is valid for the PowerShell Desktop edition only.
# CLRVersion = ''

# Processor architecture (None, X86, Amd64) required by this module
# ProcessorArchitecture = ''

# Modules that must be imported into the global environment prior to importing this module
# RequiredModules = @()

# Assemblies that must be loaded prior to importing this module
# RequiredAssemblies = @()

# Script files (.ps1) that are run in the caller's environment prior to importing this module.
# ScriptsToProcess = @()

# Type files (.ps1xml) to be loaded when importing this module
# TypesToProcess = @()

# Format files (.ps1xml) to be loaded when importing this module
# FormatsToProcess = @()

# Modules to import as nested modules of the module specified in RootModule/ModuleToProcess
# NestedModules = @()

# Functions to export from this module, for best performance, do not use wildcards and do not delete the entry, use an empty array if there are no functions to export.
FunctionsToExport = @()

# Cmdlets to export from this module, for best performance, do not use wildcards and do not delete the entry, use an empty array if there are no cmdlets to export.
CmdletsToExport = @()

# Variables to export from this module
VariablesToExport = '*'

# Aliases to export from this module, for best performance, do not use wildcards and do not delete the entry, use an empty array if there are no aliases to export.
AliasesToExport = @()

# DSC resources to export from this module
# DscResourcesToExport = @()

# List of all modules packaged with this module
# ModuleList = @()

# List of all files packaged with this module
# FileList = @()

# Private data to pass to the module specified in RootModule/ModuleToProcess. This may also contain a PSData hashtable with additional module metadata used by PowerShell.
PrivateData = @{

    PSData = @{

        # Tags applied to this module. These help with module discovery in online galleries.
        # Tags = @()

        # A URL to the license for this module.
        # LicenseUri = ''

        # A URL to the main website for this project.
        # ProjectUri = ''

        # A URL to an icon representing this module.
        # IconUri = ''

        # ReleaseNotes of this module
        # ReleaseNotes = ''

        # Prerelease string of this module
        # Prerelease = ''

        # Flag to indicate whether the module requires explicit user acceptance for install/update/save
        # RequireLicenseAcceptance = $false

        # External dependent modules of this module
        # ExternalModuleDependencies = @()

    } # End of PSData hashtable

} # End of PrivateData hashtable

# HelpInfo URI of this module
# HelpInfoURI = ''

# Default prefix for commands exported from this module. Override the default prefix using Import-Module -Prefix.
# DefaultCommandPrefix = ''

}

另请参阅