PowerShell-第1章 交互界面

1.1运行程序、脚本和已有的工具:

  Program.exe arguments

  ScriptName.ps1 arguments

  BatchFile.cmd arguments

  如果运行的命令名中包含空格,则用引号' 将命令括起来,同时在前边加上符号&,这称作调用操作,例:

    & 'C:\Program Files\Program\Program.exe' arguments

  运行当前目录下的文件

    .\Program.exe arguments

  运行当前目录下那些命令名中包含空格的命令,同时加上符号&和.\,例:

    & '.\Program Files\Program\Program.exe' arguments

  在PowerShell提示符下,进行表达式运算:

    

1.2 运行PowerShell命令

  Get-Process命令是一个内置的PowerShell命令,称之为cmdlet,为管理员和开发人员提供了重要的功能。

  1>采用同一的命令语法

  2>支持丰富的管道功能

  3>输出易于管理的对象,而不是容易出错的文本

  

1.3 自动以shell、配置文件与提示符

  PowerShell默认将你的脚本文件的地址存放在$profile变量中,可以通过这个变量来访问脚本文件。

  创建新的脚本文件(覆盖已存在的):

    New-Item -type file -force $profile

  编辑已存在的文件:

    notepad $profile

  查看配置脚本文件的内容:

    Get-ChildItem $profile

  

  修改控制窗口的标题:

    $host.UI.RawUI.WindowTitle ="标题"

  修改输出提示的颜色:

    Write-Host -ForegroundColor DarkGray "改变输出提示的颜色"

  

1.4 查找实现指定任务的命令

  获得指定命令的概要信息:  

    Get-Command CommandName

  获得指定命令的详细信息,将Get-Command的输出结果重定向到Format-List命令:

    Get-Command CommandName | Format-List

  想搜索包含"text"的所有命令,用星号*,例:

    Get-Command *text*

  想搜索所有使用Get动词的命令,在-Verb后输入参数Get,如下:

    Get-Command -Verb Get

  想搜索所有与服务有关的命令,在-Noun后加入参数Service,如下:

    Get-Command -Noun Service

1.5 获得命令帮助

  获得一个命令的概要帮助,主要包括命令的大纲,语法以及细节描述:

    Get-Help CommandName

    或者 CommandName -?

  获得一个命令的帮助信息的详情,包括参数说明和示例:

    Get-Help CommandName-Detailed

  获得一个命令的详细的帮助信息,包含全部参数描述和注释信息:  

      Get-Help CommandName -Full

  获得一个命令的例子信息,如下:

     Get-Help CommandName -Examples

  获得更多关于Get-Help的信息:

    Get-Help Get-Help

1.7 在PowerShell之外调用PowerShell脚本

  从批处理文件、登录脚本、定时任务或其他非PowerShell应用程序中调用PowerShell脚本:

    PowerShell "& 'full path to script' arguments"

    例:PowerShell "& 'C:\shared scripts\Get-Report.ps1' Hello World"

1.9 获得系统日期与时间

    Get-Date

  检查今天是星期几,如下:

    $date=Get-Date

    $date.DayOfWeek

    

  Get-Help Get-Date可以查看更多关于Get-Date的命令

1.10 检查最后运行命令的状态

  PowerShell提供了两个变量来监测最后执行的命令是否成功,这两个变量是$lastExitCode和$?

  变量$lastExitCode:

    数字型,它返回最后脚本或应用程序执行返回的退出码或出错级别

  变量是$?:

    布尔型,返回最后执行命令的成功true或失败false

  

1.11 计算命令执行的时间

  计算一个命令执行的时间:  

    Measure-Command { Start-Sleep -Milliseconds 337 }

    

1.12 PowerShell快捷键

  Up 向前搜索历史命令

  Down 向后搜索历史命令

  PgUp 显示历史命令中第一个命令

  PgDown 显示历史命令中最后一个命令

  Left 把光标向左移动一个字符

  Right 把光标向右移动一个字符

  Home 在命令行中,把光标移到开始位置

  End 在命令行中,把光标移到结束位置

  Ctrl+Left 把光标向左移动一个单词

  Ctrl+Right 把光标向右移动一个单词

1.14 使用与管理控制台历史

  获得最近使用的命令:

    Get-History

  从历史命令中获得指定的某个命令,可以将命令的ID传给Invoke-History,如下:

    Invoke-History Id

  通过给$MaximumHistoryCount赋值,可以增加或限制会话历史中存储命令的数量

    $MaximumHistoryCount =Count

  保存历史命令到文件,可以使用管道命令:

    Get-History | Export-CliXml Filename  

  将已经保存的命令加载到控制台,利用管道重定向即可

    Import-CliXml Filename | Add-History

1.15 将命令的输出保存到文件

  通过Out-File命令或者重定向操作符将命令输出的结果保存到文件中

  Out-File

    Get-ChildItem | Out-File unicodeFile.txt

    Get-Content filename.cs | Out-File -Encoding ASCII File.txt

    Get-ChildItem | Out-File-Width 120 unicodeFile.cs

  重定向操作符

    Get-ChildItem > file.txt

    Get-ChildItem 2> file.txt

1.16 向文件的结尾处加入信息

  将管道输出定向到文件中,并且在文件后面追加信息

  使用Out-File命令的参数-Append

    Get-ChildItem | Out-File -Append files.txt

  重定向操作符

    Get-ChildItem >> files.txt

1.17 记录你的会话全文

  记录当前会话的日志或全文

    Start-Transcript path

    Stop-Transcript

    path是可选项,用来指定记录的文件名,它基于当前的系统时间。默认情况下,将这个文件保存到My Documents目录下,如果想停止记录,则Stop-Transcript。

1.18 将某一项的属性显示成列表

  显示一个项的详细信息,可以使用管道命令功能把项输出给Format-List命令,例如:

    $currentError=$error[0]

    $currentError | Format-List -Force

    PowerShell中有三种格式化命令:Format-Table、Format-Wide和Format-List,Format-List获得输入将以列表方式显示出来。

    默认情况下,PowerShell从安装目录下的*.format.ps1xml文件中获得要显示的属性。如果想显示所有的属性,可以键入Format-List *。

    有些时候你键入了Format-List *,但是不能获得项的属性列表,这种情况的出现是由于在*.format.ps1xml文件中定义了项,但是没有定义任何在列表命令中药显示的条目,

    这种情况下,可以键入Format-List -Force

1.19 将某一项的属性显示成表格

  将命令的输出以管道方式输出给Format-Table,如下:

    Get-Process | Format-Table

    

  显示特定的属性

    Get-Process | Format-Table Name,WS

    

  通知PowerShell以最易阅读的方式来格式化表格,可以提供-Auto参数给Format-Table

    Get-Process | Format-Table Name,WS -Auto

    

  自定义列(以兆为单位显示一个进程的工作集),可以提供一个自定义的格式

    $fields="Name",@{Label="WS (MB)"; Expression={$_.WS / 1mb}; Align="Right"}

    Get-Process | Format-Table $fields -Auto
    

1.20 管道命令的错误输出

  列出当前会话列表中发生的所有错误,可访问$error数组:

    $error

  列出会话列表中最后发生的错误,即访问$error数组中的第一个值

    $error[0]

  列出错误的详细信息,以管道方式输出给Format-List,注意要加上-Force

    $currentError=$error[0]

    $currentError | Format-List -Force

  列出引起错误的命令的详细信息,可以访问InvocationInfo属性

    $currentError=$error[0]

    $currentError.InvocationInfo

  以更加简洁的基于分类的方式显示错误,修改变量$errorView的值

    $errorView="CategoryView"

  清除PowerShell产生的错误

    $error.Clear()

1.21 配置调试、校验和处理输出

  启动脚本和生成它的命令的调试信息的输出

    $debugPreference="Contiune"

    Start-DebugCommand

  启用命令的校验模式

    Copy-Item c:\temp\*.txt c:\temp\backup\ -Verbose

  禁用脚本或命令产生的进度信息

    $progressPreference ="SilentlyContinue"

    Ger-Process.ps1

  处理产生错误输出之外,许多脚本和命令还生成其他几种输出,包括:

  调试输出:诊断问题

    Write-Debug

    或调用WriteDebug()

    输出这类信息。除非通过$host.PrivateData.Debug*颜色配置变量来定义输出信息的颜色,否则会以黄色显示这类信息

  验证输出:监视命令的动作

    Write-Verbose

    或调用WriteVerbose()

    输出这类信息,除非通过$host.PrivateData.Verbose*颜色配置变量来定义输出信息的颜色,否则会以黄色显示这类信息

  进度输出:监视长时间运行的命令的状态

    Write-Process

    或者调用WriteProgress()

    输出这类信息,除非通过$host.PrivateData.Progress*颜色配置变量来定义输出信息的颜色,否则会以黄色显示这类信息

  一些命令只有在分别指定-Verbose或-Debug参数后才会产生炎症或调试信息。为了配置脚本或命令的调试、验证或进度信息,可以通过修改shell变量

  $debugPreference、$verbosePreference和$progressPreference来达到目的,这些变量可接受的值有:
    安静模式(silentlyContinue): 不显示输出信息

    停止模式(stop):将输出视为错误

    继续模式(continue):显示输出

    询问模式(inquire):显示继续操作信息

 

posted @ 2015-08-07 17:18  lucky_zhang  阅读(2046)  评论(0编辑  收藏  举报