PowerShell中的基础数据类型

简介:

PowerShell是一个面向对象的语言,在申明变量的时候不强制要求申明数据类型,使用$开头来申明变量即可。

基本数据类型

PowerShell本身是基于.Net开发出来的,所以在.Net中的基本数据类型,在PowerShell中也可以使用,只是在PowerShell中用”[]”来标识具体的数据类型。比如[int],[long],[string],[bool],[double]等。

使用-is来判断某个变量是否指定的数据类型,和C#中的is关键字是一样的。比如:

$a=10; 
$a  -is [int] 
$a  -is [double]

第二行返回True,第三行返回False。

我们也可以在定义变量时指定数据类型。比如我们要定义decimal类型的10,那么可以写为:

[decimal] $c=10

$c.GetType() 可以看到我们的类型为Decimal。

数据类型转换

关于默认数据类型转换,PowerShell和C#的行为有所不同。PowerShell会根据第一个变量的类型作为目标类型,然后将运算后面的联系转换为第一个类型。比如我们申明两个变量:

$a=10; 
$b= " 10 ";

如果我们使用加法运算:

$a+ $b

该运算会返回20,因为第一个变量是int类型的,所以后面的变量都会转换为int类型。如果我们调整变量的顺序:

$b+ $a

该运算返回的结果为1010,因为第一个变量是string类型。习惯了C#的默认类型转换,那么我们可以强制进行类型转换后再进行运算。强制类型转换的方法也是与C#相同。

比如我们要按int类型来计算,那么我们第二个加法可以改为:

[int] $b+ $a

我们也可以使用-as命令,那么第二个加法改为:

( $b  -as [int])+ $a

List/Array类型

我们平时使用的各种Get-XXX命令,很多都是返回对应类型的Array,比如Get-Process.

如果我们要定义一个集合,那么可以使用”@(对象1,对象2,对象3…)”的格式申明集合。比如我们定义一个字符串集合:

$a=@('a','bb','ccc')

其实不使用@和括号也是可以的,只需要用逗号分割各个Item即可。

$a='aaa','bb','c'

如果是申明一个空的集合,就必须写为:

$a=@()

与C#不同的是,在PowerShell中,往集合中添加元素,可以使用+=符号。

$a=@() 
$a+= " abc " 
$a+= " dddd " 
Write-Host  $a

如果要移除某个元素,那么就不简单了,需要使用Where查询(简写为?),找出要保留的元素,然后将保留的元素集合再重新赋值会变量。比如对于字符串集合,我们要移除字符c,那么操作如下:

$a=@('aaa','bb','c') 
$a$a | ? { $_  -ne 'c'} 
Write-Host  $a

访问某个元素使用[idx]即可和C#相同。至于对集合的各种操作,可以参见我上一篇博文

Hashtable/Dictionary类型

哈希表就是一个Key-Value对的集合。哈希表的创建格式如下:

@{Key1=Value1;Key2=Value2;…}

这里Key一般是字符串,但是并不需要用引号引起来(当然,使用了引号更好),Value可以是任意类型。比如我们创建一个员工和部门的Hashtable,命令如下:

$a=@{Devin= " IT ";Edward= " Finance ";Jeneen= " Sale "}

使用keys属性可以获得哈希表的Key列表,使用values属性可以获得Value列表。

如果要往哈希表中添加元素,可以使用.Add(Key,Value)方法。比如添加一个员工:

$a.Add( " Julia ", " Logisitcs ")

这里需要注意的是Key必须要带引号。而且哈希表的Key是不允许重复的,如果已经存在相同的值,添加会报错。可以先判断Key是否存在,然后再添加:

if( -not  $a.ContainsKey( " Julia ")) 

$a.Add( " Julia ", " Logisitcs "
}

如果要移除某个Key对应的元素,那么可以调用.Remove(Key)函数即可。

$a.Remove( " Julia ")

如果要访问某个Key对应的值,有两种方法:

$a[ " Devin "
$a.Devin

需要注意的是,直接对哈希表进行Sort-Object是没有效的,我们必须先调用GetEnumerator方法,把哈希表转换后在执行Sort。

$a.GetEnumerator() | Sort-Object Name
目录
相关文章
|
11月前
|
机器学习/深度学习 人工智能 自然语言处理
【AI系统】AI在不同领域的应用与行业影响
本文探讨了人工智能在计算机视觉、自然语言处理及音频处理等领域的广泛应用,并展示了其在自动驾驶、安全监控、搜索引擎优化、客户服务、语音识别及多个行业的革新作用,强调了AI基础设施与系统创新对未来社会的影响与价值。
972 1
|
存储 架构师 测试技术
架构之道——人人都是架构师
本文的探讨和编写主要围绕三个方面:架构是什么?架构师要解决的问题有哪些?解决这些问题的方法论是什么?最后作者希望人人都能具备架构师思维。
|
8月前
|
SQL 存储 运维
云端问道5期方案教学-基于 Hologres 轻量实时的高性能OLAP分析
本文介绍了基于Hologres的轻量实时高性能OLAP分析方案,涵盖OLAP典型应用场景及Hologres的核心能力。Hologres是阿里云的一站式实时数仓,支持多种数据源同步、多场景查询和丰富的生态工具。它解决了复杂OLAP场景中的技术栈复杂、需求响应慢、开发运维成本高、时效性差、生态兼容弱、业务间相互影响等难题。通过与ClickHouse对比,Hologres在性能、写入更新、主键支持等方面表现更优。文中还展示了小红书、乐元素等客户案例,验证了Hologres在实际应用中的优势,如免运维、查询快、成本节约等。
146 0
云端问道5期方案教学-基于 Hologres 轻量实时的高性能OLAP分析
|
11月前
|
存储 资源调度 算法
操作系统的心脏:深入理解内核架构与机制####
【10月更文挑战第16天】 本文旨在揭开操作系统最神秘的面纱——内核,通过剖析其架构设计与关键机制,引领读者一窥究竟。在这篇探索之旅中,我们将深入浅出地讨论内核的基本构成、进程管理的智慧、内存分配的策略,以及那至关重要的系统调用接口,揭示它们是如何协同工作,支撑起现代计算机系统的高效运行。这既是一次技术的深潜,也是对“看不见的手”调控数字世界的深刻理解。 ####
262 3
|
12月前
|
移动开发 前端开发 JavaScript
HTML5 Canvas详解及应用
HTML5 Canvas 允许通过 JavaScript 在网页上动态绘制图形、动画等视觉内容。首先在 HTML 中定义 `<canvas>` 元素,并通过 JavaScript 获取画布上下文进行绘制。常见方法包括绘制矩形、路径、圆形和文本,以及处理图像和创建动画效果。适用于游戏开发、数据可视化、图像编辑和动态图形展示等多种应用场景。需要注意性能优化、无状态绘制及自行处理事件等问题。
|
10月前
|
移动开发 资源调度 IDE
鸿蒙Taro实战:01-搭建开发环境
本文介绍了如何使用 Taro 4.x 框架搭建鸿蒙应用开发环境。主要内容包括:下载并配置 DevEco IDE,创建鸿蒙项目,安装 Taro 4.x,初始化 Taro 项目,配置鸿蒙插件和编译配置,修改 `package.json`,运行 Taro 和鸿蒙项目。通过本文,读者可以快速上手鸿蒙应用开发。
|
10月前
|
监控 数据可视化 搜索推荐
盘点好用的看板管理软件,优缺点一目了然!
在现代项目管理中,看板管理软件成为团队提高效率、优化流程的重要工具。本文介绍了四款热门看板软件:板栗看板、Trello、Asana 和 Monday.com,分别从功能、易用性、优缺点等方面进行了详细评测,帮助团队选择最适合自己的工具。板栗看板适合中小企业,Trello 适合初创团队,Asana 适合中大型团队,Monday.com 则适合需要高度自定义的团队。
357 0
|
11月前
|
机器学习/深度学习 人工智能 数据可视化
21款改变世界的AI工具:释放无限创意!
本文收集了21款令人惊叹的人工智能工具,每一款工具都为用户带来了创新与便捷。从数据分析、文档编写、语音克隆到图像升频,这些工具涵盖了多领域的应用。无论是自动化工作流的 n8n,还是开源替代 Notion 的 AppFlowy,这些工具都旨在通过 AI 提高生产力、简化流程,甚至激发更多创意。本文详细介绍了每个工具的用途、功能特点以及使用场景,是你探索 AI 世界的必备指南。
455 0
|
12月前
|
算法 大数据 网络安全
FP-Growth算法
FP-Growth算法
465 2
|
小程序 JavaScript 前端开发
【微信小程序-原生开发】实用教程06-轮播图、分类页签 tab 、成员列表(含Tdesign升级,切换调试基础库,设置全局样式,配置组件按需注入,添加图片素材,wx:for,生命周期 onLoad)
【微信小程序-原生开发】实用教程06-轮播图、分类页签 tab 、成员列表(含Tdesign升级,切换调试基础库,设置全局样式,配置组件按需注入,添加图片素材,wx:for,生命周期 onLoad)
379 0