zoukankan      html  css  js  c++  java
  • Powershell 函数中的CmdletBinding()是怎么回事?

    参考文章:

    Don Jones https://technet.microsoft.com/en-us/library/ff677563.aspx

    powershell 帮助文档: 

    help about_functions_advanced_parameters

    help about_common_parameters

    把这三部分内容都看完了,应该也大概了解函数中的CmdletBinding()是做什么用的了,官方的文档都是英文的,看起来一般会头大。以下就是我用通俗的语言来做的描述,更简单易懂一些。

    这个功能的引入是从Powershell Version 2开始的,叫做函数的高级功能,在函数的声明出启用以后,可以调用我们所说的通用参数:

    • -Verbose

    • -Debug

    • -ErrorAction

    • -WarningAction

    • -ErrorVariable

    • -WarningVariable

    • -OutVariable

    • -OutBuffer

    • -PipeLineVariable

    通过放在函数开始部分可以很简单的启用访问这些通用参数。如下所示:

    [CmdletBinding()]

    param()

     

    启用这个高级属性以后,就可以很容易的通过像使用命令行一样,给函数添加一些命令行的特色,调用命令很的通用参数。以下是一个最简单的例子,打开一个ISE,把以下的内容复制下去:

    function Go-Advanced {

        [cmdletbinding()]param()

    }

     

    param() 这个关键字还是必须要有的,即使你没有在函数中定义任何参数;

     

    尝试运行一下这个函数,然后再打一下中横线,怎么样,就看到能够调用的这些通用参数了吧。

    wKioL1m6Ncfi5HwjAACKVNGjzz0860.png-wh_50

    以下举几个例子来调用这些通用参数,先来说说Verbose的用法。

    还是在ISE中输入以下代码

    FunctionGo-Verbose{

        [CmdletBinding()]Param()

        Write-Verbose"Alright, you prefer talkative functions. First of all, I appreciate your wish to learn more about the common parameter -Verbose. Secondly, blah blah.."

        Write-Host"This is self-explanatory, anyway."

    }

    再执行以下,看看是不是以下结果,通过这个例子,你就明白verbose是怎么出来的,这个单词是很难翻译的,只能是通过例子弄明白是什么意思。

    wKioL1m6OIqBdfY2AAFN6yFb7bA465.png-wh_50

    再举一个例子,就是调用ShouldContinue这个方法,这个在写程序时还是很重要的,比如你想做一些破坏性的操作,程序写的健壮是一定要跳一个框出来,问一下再去执行,那种SilientContinue做法不推荐。

    以下还是代码:

    wKiom1m6Otihwc7xAAE7P9QDfFo116.png-wh_50

    这段代码还是要在函数执行时加一个 -confirm参数的。如果想不加这个参数也要跳出这个框来,这样就需要一个额外的操作。把环境变量$ConfirmPreferece 设置成低。看以下代码和执行效果。

    FunctionRemove-ByForce{

        [CmdletBinding(SupportsShouldProcess)]

        Param([String]$File)

        $ConfirmPreference="Low"

        If($PSCmdlet.ShouldContinue("Are you sure that you know what you are doing?","Delete with -Force parameter!")){ 

                Remove-Item$File-Force

        }Else{ 

                "Mission aborted!"

        }

    }

    Remove-ByForce test

    wKioL1m6O7rBqaxoAAFE2_dCbxU763.png-wh_50

    以上就是两个基本的例子,接下来的文章会讨论

    param()中的[parameter()]对变量的影响。

  • 相关阅读:
    [ERROR] Terminal initialization failed; falling back to unsupported
    设计模式原则
    设计模式:概述
    INFO Dispatcher:42
    Exception occurred during processing request: id to load is required for loading
    Java编程基础篇第六章
    Spring (一)(未完~~~
    Spring MVC处理过程理解(一)
    Spring MVC源码解析(二)
    MyBatis拦截器(一)
  • 原文地址:https://www.cnblogs.com/hjbf/p/10734530.html
Copyright © 2011-2022 走看看