Powershell可以很容易地把自己的脚本函数做成模块以便重复使用。豆子写了个简单的函数,生成帮助文档,然后另存为ps1脚本和psm1的模块,这样就可以反复调用了。


下面是一个基本流程。


首先写了一个函数,基本功能是输入操作系统名字,获取系统里面所有匹配系统的.net 版本,powershell 版本和OS的版本


function get-dotnet {

[cmdletbinding()]

param(
[parameter(mandatory=$true,position=1)][string]$osname
)


$a=Get-ADComputer -Filter "operatingsystem -like '*$osname*'" -Properties operatingsystem,ipv4address| Where-Object{$_.ipv4address -ne $null} | select -ExpandProperty name


Invoke-Command -ComputerName $a {
""| select @{name=".Net version";expression={
Get-ChildItem 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP' -Recurse | 
Get-ItemProperty -name Version -EA 0 |
Where-Object { $_.PSChildName -match '^(?!S)\p{L}'} | Sort-Object version -Descending | 
Select-Object -ExpandProperty Version -First 1 }
},@{name="PowerShell Version";e={$PSVersionTable.psversion.major}},@{name="OS Version";expression={[environment]::osversion.version.build}}
} | ft


}


结果如下

PS C:\WINDOWS\system32> get-dotnet -osname 2012
.Net version PowerShell Version OS Version PSComputerName RunspaceId                          
------------ ------------------ ---------- -------------- ----------                          
4.5.51650                     4       9600 SYDAV01        8b5bfa95-b012-47a5-b78e-8c82d7e120ff
4.5.51650                     4       9600 SYDWSUS        08579f5c-2186-4a05-a242-55a2defea0d2
4.5.51650                     4       9600 AUSSQL01       54b0b2c0-7ae8-4587-a774-d76bea7ba10e
4.5.51650                     4       9600 SYDHARD01      52a283ed-107b-4cfb-ac94-7d183b5e37fb
4.5.51650                     4       9600 SYDSRM2012     4d25f13e-8dd0-49d6-b83e-e2c0ba2bfb69
4.5.51650                     4       9600 SYDVCS2012     28aabf1a-3165-4e78-b438-0b926df1a1a8
4.5.51650                     4       9600 AUSHELP01      0132ddd2-1586-4ebf-b80e-95b1564dc6ee
4.5.51650                     4       9600 DRVCS2012      cbb49686-d565-4afc-935a-1436462b16b7
4.5.51650                     4       9600 DRRAD2012      74ec057f-bf1d-4728-b3be-1ee9b


如果要给别人使用的话,必须添加说明,方法很简单,ISE打开一个新的窗口,输入ctrl+J, 然后就可以打开模板了

创建powershell模块_第1张图片


在function的开头,依葫芦画瓢输入下面的信息,这样的话,Powershell 会自动的生成对应的帮助文档

function get-dotnet {
<#
.Synopsis
   Get .net and Powershell Version from remtoe machine
.DESCRIPTION
   Get .net and Powershell and OS Version from remtoe machine
.EXAMPLE
   get-dotnet -osname 2012
   This will get the .net, powershell and OS version of connected Windows 2012 Server
.EXAMPLE
   get-dotnet -osname "2012 R2"
   This will get the .net, powershell and OS version of connected Windows 2012 R2 Server
.INPUTS
   String name of OS, such as winows 7, 2008, 2012 etc
.OUTPUTS
   Output from this cmdlet (if any)
.NOTES
   This is a test function
.COMPONENT
   The component this cmdlet belongs to Yuan Li
.ROLE
   The role this cmdlet belongs to Yuan Li
.FUNCTIONALITY
   The functionality that best describes this cmdlet
#>

[cmdletbinding()]


Powershell自动的生成了对应的帮助文档,很赞啊

PS C:\WINDOWS\system32> help get-dotnet -full
NAME
    get-dotnet
    
SYNOPSIS
    Get .net and Powershell Version from remtoe machine
    
SYNTAX
    get-dotnet [-osname]  []
    
    
DESCRIPTION
    Get .net and Powershell and OS Version from remtoe machine
    
PARAMETERS
    -osname 
        
        Required?                    true
        Position?                    2
        Default value                
        Accept pipeline input?       false
        Accept wildcard characters?  false
        
    
        This cmdlet supports the common parameters: Verbose, Debug,
        ErrorAction, ErrorVariable, WarningAction, WarningVariable,
        OutBuffer, PipelineVariable, and OutVariable. For more information, see 
        about_CommonParameters (http://go.microsoft.com/fwlink/?LinkID=113216). 
    
INPUTS
    String name of OS, such as winows 7, 2008, 2012 etc
        
    
    
    
OUTPUTS
    Output from this cmdlet (if any)
        
    
    
    
NOTES
    
    
        This is a test function
    
    -------------------------- EXAMPLE 1 --------------------------
    
    PS C:\>get-dotnet -osname 2012
    
    
    This will get the .net, powershell and OS version of connected Windows 2012 Server

    

保存Powershell脚本的时候,默认的后缀是ps1。比如我另存为 get-dotnet.ps1,如果我试图调用其中的函数,我需要使用 dot source的格式,比如 

PS C:\scripts> . .\get-dotnet.ps1


如果我另存为psm1的格式,那么我可以把他视作一个模块,直接导入

PS C:\scripts> 
PS C:\scripts> Import-Module .\get-dotnet.psm1
PS C:\scripts> get-module
ModuleType Version    Name                                ExportedCommands                                                                                                  
---------- -------    ----                                ----------------                                                                                                  
Script     0.0        get-dotnet                          get-dotnet                                                                                                        
Script     1.0.0.0    ISE                                 {Get-IseSnippet, Import-IseSnippet, New-IseSnippet}                                                               
Manifest   3.1.0.0    Microsoft.PowerShell.Management     {Add-Computer, Add-Content, Checkpoint-Computer, Clear-Content...}                                                
Manifest   3.1.0.0    Microsoft.PowerShell.Utility        {Add-Member, Add-Type, Clear-Variable, Compare-Object...}                                                         
Script     1.0        tmp_otuyg3x2.xlk                    {Add-ADComputerServiceAccount, Add-ADDomainControllerPasswordReplicationPolicy, Add-ADFineGrainedPasswordPolicy...


为了更省事,我可以直接搜索模块的默认路径,把我自定义的模块保存进去,那么每次打开ISE就会自动执行了。


比如查看当前的路径,豆子的版本是powershell5

PS C:\scripts> $env:PSModulePath
C:\Program Files (x86)\VMware\Infrastructure\vSphere PowerCLI\Modules;C:\Program Files\WindowsPowerShell\Modules;C:\WINDOWS\system32\WindowsPowerShell\v1.0\Modules\;C:\Prog
ram Files (x86)\Microsoft SQL Server\110\Tools\PowerShell\Modules\
PS C:\scripts> $env:PSModulePath.Split(";")
C:\Program Files (x86)\VMware\Infrastructure\vSphere PowerCLI\Modules
C:\Program Files\WindowsPowerShell\Modules
C:\WINDOWS\system32\WindowsPowerShell\v1.0\Modules\
C:\Program Files (x86)\Microsoft SQL Server\110\Tools\PowerShell\Modules\


我直接对应的一个目录下创建一个同名的文件夹,把psm1文件放进去


创建powershell模块_第2张图片


重启ISE,发现模块已经自动加载了


创建powershell模块_第3张图片