视频地址:【黑客基础】Windows PowerShell 脚本学习

2019.12.05 学习笔记

1、$PSVersionTable :查看PowerShell的版本信息。
2、PowerShell 界面:
  • 开始界面搜索 “PowerShell” ,点击 “PowerShell.exe” 或者 “PowerShell ISE”。
  • cmd 命令界面输入 “PowerShell”。
3、PowerShell 快捷键
  • Alt + F7 :清除命令等历史记录,相当于 cls 命令。
  • Ctrl + PgUp :上翻页。
  • Ctrl + PgDn :下翻页。
  • 上下箭头键 :切换命令行等历史记录。
  • 左/右箭头键 :左右移动光标。
  • Ctrl + Home :
  • Ctrl + End :
  • ESC:清空当前命令行。
  • Tab :自动补齐并选择补齐命令或文件名。
  • Enter :执行当前的命令。
  • Ctrl + C :取消正在执行等命令。
  • Backspace :从右删除命令行字符。
  • F2 :自动补充历史命令到指定字符。
  • F4 :删除命令行至光标右边指定等字符处。
  • F7 :对话框显示命令行历史记录。
  • F8 :检索包含指定字符的命令行历史记录。
  • F9 :根据命令行等历史记录编号选择命令,历史记录编号可以通过 F7 查看。
4、PowerShell 的管道
  • PowerShell 的管道是基于对象的,和Linux Shell 基于文本不同。
  • 管道:前一个命令的输出作为下一个命令的输入。
  • 重定向:
    • “>” 表示输出到某文件,覆盖文件原有的内容,如果文件不存在则自动创建。
    • “>>” 表示添加到某文件内容的结尾。
5、PowerShell 的运算符
  • 支持四则运算
  • 支持数值的进制转换
  • 支持逻辑运算
6、PowerShell 使用外部命令
  • PowerShell 是 cmd 的扩展,cmd 的命令在 PowerShell 中基本都可以使用执行。

  • netstat -ano :查看端口信息,同 cmd 命令。

  • ipconfig :查看网络配置信息,同 cmd 命令。

  • route print :打印路由信息,同 cmd 命令。

  • start :打开应用程序。

  • notepad :打开文本编辑器,同 cmd 命令。

  • calc :打开计算器,同 cmd 命令。

  • &"command" :打开PowerShell 外部命令,PowerShell 专用。

  • $env:path :输出 path 环境变量的内容。

  • $env:path = $env:path + "dir_path" :临时添加 path 环境变量。

7、PowerShell 的命令集
  • Get-Command :获取 PowerShell 所有的命令。
  • PowerShell 的命令类型有 Alias 、Function 、Cmdlet 三种。
  • Alias :别名。
  • Function :函数。
  • Cmdlet :PowerShell 内部命令,以动-名词的格式命名。
  • Get-Help :获取命令的帮助信息。
  • Get-process :获取系统的进程信息。
  • Get-Alias :获取别名对应的命令信息。
  • Get-History :获取命令行使用命令的历史信息。
  • Get-Date:获取当前的日期时间信息。
8、PowerShell 的别名
  • Get-Help :获取命令的帮助信息,包含命令的别名信息。
  • Get-Alias :获取别名对应的命令信息。
  • Get-Alias -name "ls" :获取别名是“ls”的PowerShell命令。
  • Get-Alias | where {$_.definition.startswith("Remove")} :获取以“Remove”开头命令的别名信息。
  • Get-Alias | Group-Object definition | sort -descending Count :根据命令别名的个数倒序显示命令及其别名。
9、自定义别名
  • Set-Alias :定义命令的别名。

    • Set-Alias -name txt -value notepad
    • -name :指定命令的别名。
    • -value :指定需要定义别名的命令。
  • del alias:txt :删除别名“txt”。
  • Export-Alias :导出别名,Export-Alias demo.ps1
  • Import-Alias :导入别名,Import-Alias demo.ps1,不成功可以使用“-force”参数进行强制导入。
10、PowerShell 变量
  • PowerShell 使用 $ 符号来定义变量,不需要指定变量类型。
  • $var_name
  • $var_name = value
  • PowerShell 对大小写不敏感。
  • 定义变量使用特别的变量名需要使用花括号将变量名括起来。
  • 变量的赋值可以是别名、命令、表达式等。
  • 多个变量可以同时赋值。
11、变量操作
  • 两个变量的值互换:

    • $tempt = $var1
      $var_1 = $var_2
      $var_2 = $tempt
    • $var_1,$var_2 = $var_2,$var_1
  • ls variable:: 查看当前使用的变量。

  • ls variable:var_name: 查看变量 $var_name 的信息,支持正则表达式。

  • Test-Path variable:var_name :查看变量 $var_name 是否存在,返回布尔值。

  • del variable:var_name :删除指定的变量。

  • Clear-Variable :清除指定的变量。

  • Remove-Variable:删除指定的变量。

12、PowerShell 自动化变量
  • 自动化变量是由 PowerShell 自己创建和维护的,一些变量是只读而不能写入的。
  • $home :用户根目录路径。
  • $pid :当前界面进程的ID。
  • $$ :上一个运行的命令。
  • $? :上一个命令运行的状态,返回布尔值。
  • $_ :当前变量。
  • $null :空值,空变量。
13、PowerShell 环境变量
  • ls env: :查看环境变量信息。
  • env:var_name :显示指定的环境变量信息,支持正则表达式。
  • env:varname=value :创建添加一个环境变量。
  • del env:var_name :删除指定的环境变量,支持正则表达式。
  • [environment]::setenvironmentvariable("PATH","D:\","User"):设置用户的 $PATH 变量,永久生效。
  • [environment]::getenvironmentvariable("PATH","User"):获取环境变量 $PATH 。
14、PowerShell 脚本执行策略
  • PowerShell 脚本以 .ps1 后缀。
  • Get-Executionpolicy :查看命令行的脚本执行权限,返回 Restricted 表示禁止。
  • Set-Executionpolicy RemoteSigned :允许命令行运行 PowerShell 脚本。
15、PowerShell 脚本调用
  • 切换到桌面:cd desktop
  • & “PowerShell_script_path” :执行脚本。
  • .bat 脚本文件调用PowerShell 脚本:powershell "& 'PowerShell_script_path'"

【黑客基础】Windows PowerShell 脚本学习(上)的更多相关文章

  1. 使用Windows任务计划程序运行Windows PowerShell脚本

    创建计划任务以运行PowerShell脚本 我需要创建一个计划任务来运行Windows PowerShell脚本的第一件事是我将执行的命令行.找到这个的简单方法是使用Run 命令.有时,我需要知道什么 ...

  2. Windows bat脚本学习(1)

    基础 首先所有命令在cmd命令行中都能找到说明: 例如 想知道type用法 输入type /? 其他命令都一样 type [drive:][path] filename 显示文本文件内容 虽然有点鸡肋 ...

  3. Windows Powershell脚本执行

    在cmd下执行powershell进入shell模式: 变量定义:$i = 10 $a = ifconfig | findstr "192" Windows下的命令都可以执行如: ...

  4. 【SharePoint学习笔记】第2章 SharePoint Windows PowerShell 指南

    快速了解Windows PowerShell     从SharePoint 2010开始支持PowerShell,仍支持stsadm.exe工具:     可以调用.NET对象.COM对象.exe文 ...

  5. SharePoint 2010 最佳实践学习总结------第2章 SharePoint Windows PowerShell指南

    第2章 SharePoint Windows PowerShell指南 SharePoint 2010是SharePoint系列产品中第一个开始支持Windows PowerShell的产品,在以前的 ...

  6. Windows PowerShell基本语法及常用命令

    PowerShell常用命令: 一 Get类 1.Get-Command : 得到所有PowerShell命令,获取有关 cmdlet 以及有关 Windows PowerShell 命令的其他元素的 ...

  7. windows powershell学习

    PowerShell,从名字可以知道,他首先是一个shell,shell的意思就是和Linux的bash等一样.和原来的cmd一样就是在里边敲命令(可执行文件)使用: 而Power就意味他是一个功能强 ...

  8. Bat 脚本学习 (基础篇)

    [转]Bat 脚本学习 2015-01-05 14:13 115人阅读 评论(0) 收藏 举报 基础部分: ============================================== ...

  9. windows powershell基础

    windows powershell基础 目录: 1.管道和重定向 2.命令执行 3.变量 4.数组和哈希表 #@()创建数组,使用","把每个值分隔开,@{}创建哈希表,用&qu ...

随机推荐

  1. Linux后台运行Jar方法

    原文地址:http://blog.csdn.net/c1481118216 https://blog.csdn.net/c1481118216/article/details/53010963 在li ...

  2. access 2013下载 access 2010下载 access 2007下载 Access 2003下载 安装交流的论坛

    在网上搜索了一个access 2013下载 access 2010下载 access 2007下载 Access 2003下载 安装交流的论坛 office安装的常见问题: http://www.of ...

  3. 文件I/O——文件打开函数(open/openat)

    一.open函数 1.函数原型:int open(const char *path,int oflag,.../* mode_t mode */); 2.头文件:#include <fcntl. ...

  4. Java虚拟机之垃圾回收

    简述 Java与那些较传统的语言比如C++有个很大不同就是垃圾回收策略了.前者通常是虚拟机自动帮我们做了,而后者就需要我们手动来完成. Java虚拟机帮我们完成了垃圾回收,是不是意味着我们就不用完全去 ...

  5. group 状压dp

    应某些人要求,我把标签删掉了 这是一道好题. 一看$c<=16$果断状压,但是怎么压? 一个很显然的思路是,枚举上下两层的状态,每一层的状态极限有$C(c,c/2)$,c=16的时候有13000 ...

  6. Spring Boot 2.x监控数据可视化(Actuator + Prometheus + Grafana手把手)

    TIPS 本文基于Spring Boot 2.1.4,理论支持Spring Boot 2.x所有版本 众所周知,Spring Boot有个子项目Spring Boot Actuator,它为应用提供了 ...

  7. ELK分布式日志+NLog在.NetCore中的应用

    一.ELK简介 ELK是Elasticsearch.Logstash和Kibana首字母的缩写.这三者均是开源软件,这三套开源工具组合起来形成了一套强大的集中式日志管理平台 Elasticsearch ...

  8. 去除word文档页眉处的横杠

    ​ 如何去除上图word文档页眉处的横杠 wps软件使用者 第一步双击页眉,到页眉页脚: ​ 第一步点击上图页眉横线,点击无线型或者删除横线即可: ​ ​ ​ Microsoft Office 专业增 ...

  9. Mac下配置nacos开机启动

    nacos能正常启动后,开始制作启动app. 1.打开自带的 自动操作 2.点击选项 3.选择应用程序 4.搜索shell,点击运行Shell脚本,写入脚本,$NACOS 为nacos的绝对路径,保存 ...

  10. PHP获取PHP执行的时间

    php获取PHP执行的时间 <pre> //程序运行时间 $starttime = explode(' ',microtime()); //代码区域 //程序运行时间 $endtime = ...