【探索PowerShell 】【八】数组、哈希表(附:复制粘贴技巧)

简介:

我们经常在程序设计中用到的数组,同样在脚本中很常用。本节就详细介绍一下数组,以及哈希表在PowerShell中的使用。

数组

在PowerShell中,声明一个变量为数组时,需要使用符号"@",例如:

 

$strUsers=@(""user1","user2","user3) <enter> 

这样,我们就声明了一个具有3个成员的数组。查看它的值,使用:

 

$strUsers <enter> 

还有一些其他的操作,如统计一个数组的成员数目:

 

$strUsers.Count <enter> 

查看或者为数组成员单独赋值(需要注意的是,PowerShell与大多数程序语言一样,数组成员下标从0开始计数):

 

$strUsers[0] <enter>

$strUsers[1]="marui" <enter>

也可以使用加号合并数组,如:

哈希表

哈希表,也就是字典,是一种非常优秀的数据结构,允许我们使用关键字进行查询,它几乎没有性能损失,这些都是因为它的基本结构能够很好的符合计算机存储运算特性。

在声明哈希表变量时,同样需要用到符号"@",如:

 

$age=@{} <enter> "MaRui"=21;"Lee"=27;"Tom"=53

与数组相似的也有如下操作:

 
  1. 查询  
  2. $age["MaRui"] <enter>  
  3.  
  4. 增加(注意,增加的同时一定要赋值,否则不会添加新条目)  
  5. $age["Ma"]=24 <enter>  
  6.  
  7. 修改  
  8. $age["Ma"]=25 <enter>  
  9.  
  10. 删除(注意,使用圆括号)  
  11. $age.remove("Ma") <enter>  
  12.  
  13. 清除哈希表  
  14. $age.clear() <enter> 

这节的内容很简单,就讲到这里。感谢各位花时间来浏览我的博客!


下去之后,有人问及我在PowerShell中如何进行复制粘贴,其实方法很简单,使用鼠标右键就可以了。

复制

我使用一个cmdlet来查看BIOS信息,并且复制它:

 

get-wmiobject -class Win32_BIOS <enter> 

Step 1:

使用鼠标左键直接选取要复制的内容

Step 2:

在被选取区域单击鼠标右键即被复制。

现在粘贴到这里:

SMBIOSBIOSVersion : 7UET82WW (3.12 )
Manufacturer      : LENOVO
Name              : Ver 1.00PARTTBL(
SerialNumber      : R8RNGG3
Version           : LENOVO - 3120

粘贴

Step 1:

复制内容,请各位试试复制下面的脚本内容(此脚本用来查看BIOS的详细信息):

 
  1. $info = get-wmiobject -class Win32_BIOS -namespace root\CIMV2 -comp .  
  2.  
  3. foreach ($objItem in $info) {  
  4. write-host “BIOS Characteristics: ” $objItem.BiosCharacteristics  
  5. write-host “BIOS Version: ” $objItem.BIOSVersion  
  6. write-host “Build Number: ” $objItem.BuildNumber  
  7. write-host “Caption: ” $objItem.Caption  
  8. write-host “Code Set: ” $objItem.CodeSet  
  9. write-host “Current Language: ” $objItem.CurrentLanguage  
  10. write-host “Description: ” $objItem.Description  
  11. write-host “Identification Code: ” $objItem.IdentificationCode  
  12. write-host “Installable Languages: ” $objItem.InstallableLanguages  
  13. write-host “Installation Date: ” $objItem.InstallDate  
  14. write-host “Language Edition: ” $objItem.LanguageEdition  
  15. write-host “List Of Languages: ” $objItem.ListOfLanguages  
  16. write-host “Manufacturer: ” $objItem.Manufacturer  
  17. write-host “Name: ” $objItem.Name 
  18. write-host “Other Target Operating System: ” $objItem.OtherTargetOS  
  19. write-host “Primary BIOS: ” $objItem.PrimaryBIOS  
  20. write-host “Release Date: ” $objItem.ReleaseDate  
  21. write-host “Serial Number: ” $objItem.SerialNumber  
  22. write-host “SMBIOS BIOS Version: ” $objItem.SMBIOSBIOSVersion  
  23. write-host “SMBIOS Major Version: ” $objItem.SMBIOSMajorVersion  
  24. write-host “SMBIOS Minor Version: ” $objItem.SMBIOSMinorVersion  
  25. write-host “SMBIOS Present: ” $objItem.SMBIOSPresent  
  26. write-host “Software Element ID: ” $objItem.SoftwareElementID  
  27. write-host “Software Element State: ” $objItem.SoftwareElementState  
  28. write-host “Status: ” $objItem.Status  
  29. write-host “Target Operating System: ” $objItem.TargetOperatingSystem  
  30. write-host “Version: ” $objItem.Version  
  31. write-host  

Step 2:

在PowerShell中单击鼠标右键即可。

看看结果:

再enter一下就执行了,各位自己看结果吧。




     本文转自melvillo 51CTO博客,原文链接:http://blog.51cto.com/marui/293506,如需转载请自行联系原作者




相关文章
|
11月前
|
安全 定位技术 索引
Powershell 数据容器:数组、ArrayList 与 哈希表
本文介绍 Powershell 语言中的主要数据容器: 数组、ArrayList 与 哈希表
352 0
|
3月前
|
存储 Ubuntu Linux
windows可以安装Ubuntu,ubuntu上也可以安装Powershell
powerhsell除了可以在windows上使用外,还可以在Ubuntu上部署开发环境。下面介绍Ubuntu上安装powershell的方法。
50 0
|
5月前
|
Shell Linux 开发工具
windows中cmd和PowerShell批处理命令
之前在 Git 批量删除本地分支,有用到 Linux 或 MacOS 下的批处理命令,这个命令中的 grep、xargs 本身是 Shell script,在 windows 中的 cmd 和 PowerShell 中是不能用的
51 0
|
8月前
|
JavaScript Windows
[Vue]解决 Windows PowerShell 不识别 vue 命令的问题
[Vue]解决 Windows PowerShell 不识别 vue 命令的问题
|
8月前
|
Windows
使用PowerShell获取Windows当前锁屏壁纸
使用PowerShell获取Windows当前锁屏壁纸 如果原始图片丢了,用这段代码就可以提取当前锁屏壁纸了!
99 0
|
应用服务中间件 nginx Windows
Windows PowerShell 中启动 Nginx 报错解决方案
Windows PowerShell 中启动 Nginx 报错解决方案
Windows PowerShell 中启动 Nginx 报错解决方案
|
XML 监控 数据格式
利用powershell进行windows日志分析
0x00 前言   Windows 中提供了 2 个分析事件日志的 PowerShell cmdlet:一个是Get-WinEvent,超级强大,但使用起来比较麻烦;另一个是Get-EventLog,使得起来相当简单,可以实时筛选,接下来,我们利用PowerShell 来自动筛选 Windows 事件日志。
2437 0
|
监控 Windows
Windows Server端口监控之powershell脚本
powershell检测端口并重启程序
603 0