在 PowerShell 中把 CSV 文件导入数组中
我们经常看到来自不同来源的各种格式的数据。通常,用于数据提取的标准格式是 CSV 格式。
本文将讨论如何使用 PowerShell 读取逗号分隔的文件或 CSV 数据并将其放入数组变量中。
逗号分隔值文件
CSV(逗号分隔值)文件包含用逗号分隔的数据或集合。这允许以表格格式保存数据。
用户可以将 CSV 文件用于大多数电子表格程序,例如 Microsoft Excel 或 Google 电子表格。但是,当我们在不支持表格格式的软件中打开它时,数据将以逗号分隔,PowerShell 可以使用它来将值分隔为数组。
例如,下面是包含两列的原始 CSV 格式。
users.csv
文件:
Name,Salary
John,1000
Paul,2000
Mary,1500
Matt,3000
在 PowerShell 中使用 Import-CSV
Cmdlet 将 CSV 文件导入数组
Windows PowerShell 中的 Import-CSV
命令根据上述 CSV 文件中显示的项目创建一个类似于自定义对象的表。
在下面的 Windows PowerShell 脚本中,我们将使用 Import-CSV
命令将 CSV 文件数据分配给 Windows PowerShell 数组类型变量。
$users = Import-CSV C:\PS\users.csv
$users
执行后,我们可以看到 CSV 文件值转换为称为 ArrayList 对象的格式列表。
输出:
Name Salary
---- ------
John 1000
Paul 2000
Mary 1500
Matt 3000
在 PowerShell 中将 CSV 文件导入数组后访问元素
使用 Import-CSV
cmdlet 创建数组后,我们可以访问多个数组元素。
要访问数组中的所有元素,我们可以像前面的示例一样使用对象。
$users = Import-CSV C:\PS\users.csv
$users
输出:
Name Salary
---- ------
John 1000
Paul 2000
Mary 1500
Matt 3000
要从数组中查询元素,我们可以将索引指示符附加到变量。下面的示例使用索引 0 指示符查询数组中的第一个数据。
$users = Import-CSV C:\PS\users.csv
$users[0]
输出:
Name Salary
---- ------
John 1000
我们可以通过将列名称视为属性名称来从 Windows PowerShell 数组中的特定元素中查询属性,如下例所示。
$users = Import-CSV C:\PS\users.csv
$users[0].Name
输出:
John
我们可以使用下面的 count 属性来计算数组中元素的数量。
$users = Import-CSV C:\PS\users.csv
$users.Count
输出:
4
Marion specializes in anything Microsoft-related and always tries to work and apply code in an IT infrastructure.
LinkedIn相关文章 - PowerShell Array
- 使用 PowerShell 对数组值进行排序
- PowerShell 多维数组
- 从 PowerShell 数组中删除重复值
- 将对象添加到 PowerShell 中的对象数组
- 在 PowerShell 中创建数组、哈希表和字典