一個腳本的功能可能有很多,但是並非都是通過一段代碼來完成的。在一個出色的腳本中,實現各個功能代碼的獨立性,可以保證這個腳本具有高可用性和易維護性,並且當我們改進或刪減功能時只需刪除對應的代碼塊即可。通常,代碼塊就是指函數,調用函數,就是執行不同的代碼塊,以便實現各種功能。
先看一個例子:
function Time {Get-Date} <enter>
這樣,我們就有了一個新函數"Time",其功能實現代碼就是"{Get-Date}"。
嘗試調用它:
與編程語言一樣,自定義函數同樣可以聲明參數:
function(關鍵字) 函數名 (參數) {代碼}
例如:
function add ($x,$y)
{
$n = $x + $y
“$x+$y=$n”
}
運行結果:
在上例這個add函數中,如果參數為空,則不會產生運算。並且,在上例中的變量$n僅對函數內部有效,在函數之外,是不存在此變量的,也就是說,$n是一個局部變量。
上面的代碼還可以用另一種方法來實現:
function add
{
param ($x,$y)
$n = $x + $y
“$x+$y=$n”
}
其中,"param"的作用是聲明參數。
大多數函數對於參數的數據類型都是有要求的,例如上列示例,如果要求函數實現運算功能,則要求參數使用數字類型,如果要求的功能是字符串相加,則要求為字符類型。這就要求在編寫函數時,聲明參數的同時聲明其數據類型,最好也賦予其默認值,這樣在調用時才不會發生錯誤,其實很多錯誤可能已經發生但是我們卻看不到,因為不一定所有的函數都有輸出,可能只是將結果進行傳遞,這樣,將會給排錯帶來很大困難。
例:
function add
{
param ([int]$x=0,[int]$y=0)
$n = $x + $y
"$x+$y=$n"
}
那麼,通過前面教程的內容,可以知道,很多功能的實現並不是通過簡單的參數傳遞,而是使用了管道符"|",那麼,如何讓我們的函數也支持管道符功能呢?
只需在函數中需要接受數據的地方使用"$input"變量即可。如下例所示:
function FindWindowsFolder
{
$input | where-object {$_.Name -eq "Windows"}
}
使用如下語句調用:
ls -path c:\ | FindWindowsFolder <enter>
運行結果:
函數的階段處理
在函數中,還可以進一步分為下列3個處理步驟:
1. begin - 只在函數第一次開始時執行一次,適用於放置初始化函數的代碼。
2. process - 每一次調用函數時都執行
3. end - 只在函數結束時執行一次
並不是所有的函數都需要這三個步驟,但是一旦選擇使用這種函數表達格式,在這三個代碼塊之外不能再存在其他代碼,並且,每個代碼塊只能出現一次。
一個典型的例子:
function fun{
begin{
"Start"
$i=1
}
process{
"run "+$i
$_.name
$i++
}
end{
"End"
}
}
ls | fun
運行結果:
出處http://marui.blog.51cto.com/1034148/294775