概述

写下本篇文章源于参加Tech.Ed的一场关于Window PowerShell的课程。虽然之前也经常关注,但从没有亲自体验过。Windows PowerShell 是一种新的命令行外壳和脚本语言,用于进行系统管理和自动化任务,它建立在 .NET Framework 的基础上,可使 IT 专业人员和开发人员控制和自动完成Windows 和应用程序的管理。更为强大之处在于它可以调用.NET Framework中的类库,可以与COM、ADO、XML等交互。在本文中让我们一起来体会一下回归Doc操作的快感,进入强大无比的Windows PowerShell世界。
在Windows PowerShell中包括了:
1. 129 个命令行工具(称为“cmdlet”),用于执行常见系统管理任务,如管理服务、进程、事件日志、证书、注册表以及使用 Windows Management Instrumentation (WMI)。
2. 采用标准命名约定和通用参数的命令行工具,易于掌握和使用;以及用于对数据和对象进行排序、筛选以及格式设置的简便工具。
3. 对现有脚本语言、现有命令行工具以及多种 Windows 版本的支持,其中包括 Windows XP、Windows Server 2003、Windows Vista 以及 Windows Server 2008。
4. 方便的功能,使用户能够浏览数据存储(如注册表和证书存储),就像面对文件系统一样。
5. 用于管理位于不同存储中以及采用不同格式的 Windows 数据的标准实用程序,这些数据包括 Active Directory (ADSI)、Windows Management Instrumentation (WMI)、组件对象模型 (COM) 对象、ActiveX 数据对象 (ADO)、HTML 和 XML。
6. 在命令行进行的高级表达式分析和 .NET 对象处理,其中包括对对象进行流水线处理以帮助提高 IT 专业人员的工作效率。
7. 可扩展的接口,使独立软件供应商和企业开发人员能够构建自定义 cmdlet 以满足特有的应用程序和系统管理要求。

简单示例

在开始之前,先来看一个简单的示例,在.NET中获取当前系统所有进程的一段代码:
static void Main(string[] args)
{
    Process[] proceses = Process.GetProcesses();
    foreach (var item in proceses)
    {
        Console.WriteLine(item.ProcessName);
    }
    Console.ReadLine();
}
非常简单的一段代码,直接获取所有进程并显示出它们的名称,如下图所示:
在安装完Windows PowerShell之后,可以看到它的界面与常用的命令行界面非常相似。现在再使用Windows PowerShell来获取一下当前系统所有的进程,只有一个命令就可以完成:
Get-Process
输出如下图所示:
 

PowerShell命令

在Windows PowerShell中,内置了129个命令供我们使用,这些命令称之为“Cmdlet”。除了很多在Dos中的命令继续可以使用之外,还有PowerShell内置的一些命令。每个命令由两部分组成,前半部分表示动作,后半部分表示动作的标的,如Get-Help、Get-Command、Write-Host等。在Windows PowerShell中输入命令时,不需要输入全部名称,可以只输入其中几个关键字,PowerShell会自动匹配,如只输入get-he,然后按下“Tab”键,屏幕上就可以出现完整的Get-Help命令。
Get-Help、Get-Command是PowerShell中非常重要的两个命令,可以获取帮助和获取所有的命令列表,如输入:
Get-Command
结果如下图所示,列出了所有的命令:

与.NET Framework交互

Windows PowerShell更强大的地方在于它可以访问.NET Framework的类库,我们可以使用New-Object命令来创建一个.NET  Framework中的类实例,并保存在变量中,如下面的命令:
$d = New-Object -TypeName System.DateTime
这里使用New-Object来创建一个DateTime对象,使用-TypeName指定类型名称,创建的对象保存在$d变量中,输出结果如下图所示:
除此之外,还可以使用-ArgumentList来指定参数,如下图所示:
 

与COM交互

使用Windows PowerShell还可以完全与COM交互,这使的Windows PowerShell的功能更加强大,有了上面前面提到的访问WMI、与.NET Framework交互,再加上与COM交互,可以说Windows PowerShell几乎无所不能。如下面看一个例子,使用PowerShell来访问IE,可以使用如下命令来创建一个IE的对象,并让它导航到博客园首页:
$ie = New-Object -ComObject InternetExplorer.Application
$ie.Visible = $true
$ie.Navigate("http://www.cnblogs.com")
$ie.Quit()
简单解释一下这段代码,首先创建一个IE的COM对象,并让它显示,然后导航到博客园首页,最后程序退出。如下图所示:
 
在这个过程中,大家会看到系统打开了一个IE窗口,并且导航到了博客园。

访问注册表

除此之外,Windows PowerShell还可以实现对注册表的完全控制,包括查询所有的Entry,或者修改、删除键值等,可以说是一切皆可控制,如使用下面的命令:
Get-ChildItem -Path hkcu:\
输出如下图所示,列出了HKEY_CURRENT_USER下面的信息:

创建别名

在Windows PowerShell中,还允许为命令创建自己熟悉的别名,这样对于某些太长的命令名可以使用自己的缩写来表示,或者对于某些不太容易记忆的命令,使用自己喜欢的名字来表示。
Set-Alias gh Get-Help
这里设置gh为Get-Help命令的别名,这样在后面的操作中,当输入gh后,执行的命名就是Get-Help,如下图所示:
 

输出文件

在Windows PowerShell中,我们还可以把操作的结果输出到一个文件中,可以使用Out-File命令,另外可以使用-FilePath来指定输出的路径和文件名,如下命令所示:
Get-Process | Out-File -FilePath C:\temp.txt
现在打开C盘的temp.txt文件,可以看到输出的结果如下所示:
Handles  NPM(K)    PM(K)      WS(K) VM(M)   CPU(s)     Id ProcessName 
-------  ------    -----      ----- -----   ------     -- ----------- 
    126       4    13272      10220    47            1204 audiodg
     73       4     2936       8080    61     1.05   3580 conime
    512       5     2188       4112    59     2.06    532 csrss
    511       7     5704      19744   182    93.44    588 csrss
   1249     109   127144     157128   561    44.67   6648 devenv 
    188       8    47088      73332   164 2,020.61   2508 dwm 
   2261      48    75040      72600   416   341.38   2548 explorer
      0       0        0         24     0               0 Idle  
    664      28    36696      49076   173    14.78   3384 iexplore
    969      35    74868      87576   328    43.92   7480 iexplore
    404      10     7280        640    96     6.23   2812 kavstart 
     65       3     1368       3360    46     0.09    316 kissvc
     80       5     6592       1012    62     1.28    496 kmailmon
以上所介绍只是Windows PowerShell强大功能的冰山之一角,除此之外,还可以与WMI交互,访问机器设备,对于输出结果格式化等等,这里不再介绍。

总结

本文中简单介绍了一下Windows PowerShell,相信通过这些介绍大家已经看到了Windows PowerShell的强大之处,而且在微软以后的产品中,都会支持使用PowerShell进行管理。