c# - 相当于 LINQ 的 Select 命令的 Powershell?

标签 c# .net linq powershell

我正在尝试运行以下 Powershell 脚本。

import-module ActiveDirectory

$computers = Get-ADComputer -filter * -SearchBase "OU=myOU,DC=vw,DC=local" | select-object name

Invoke-Command -ComputerName $computers -ScriptBlock {gpupdate /target:Computer}

问题是 $computers 不是 -ComputerName 预期的 string[]。它实际上是一组 ADComputer,带有一个名为 name 的参数。

# Get-ADComputer -filter * -SearchBase "OU=myOU,DC=vw,DC=local" | select-object name | Format-Custom

class ADComputer
{
  name = PC1
}

class ADComputer
{
  name = PC2
}

class ADComputer
{
  name = PC3
}

获取名称字符串数组的正确方法是什么?如果我在 C# 中,我知道它会是

string[] computerNames = computers.Select(computer => computer.name).ToArray();

但我想学习如何在 Powershell 中正确执行此操作。

最佳答案

你可以使用

Select-Object -ExpandProperty Name

或(可能是最接近的等价物)

ForEach-Object { $_.Name }

请注意,要强制结果为数组(例如,如果您想访问其 Count 属性),您应该用 @() 将表达式括起来。否则结果可能是数组单个对象。

关于c# - 相当于 LINQ 的 Select 命令的 Powershell?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10921712/

相关文章:

c# - 通用抽象方法

c# - 如何在 C# 中格式化数字,使 12523 变为 "12K", 2323542 变为 "2M"等?

.net - 这个 XPath 查询有什么问题?

c# - 如何使用 Linq 反序列化 xml?

c# - 有没有更好的方法来为队列实现 Remove 方法?

c# - 使用正则表达式捕获分隔符内的子字符串并排除字符

c# - 将间接依赖项添加到输出

c# - 在 C# 中捕获网络流量

c# - 使用带有存储过程的 Linq 是否比使用带有生成 SQL 的 Linq 执行得更好?

c# - Entity Framework 5 过滤并包含导航属性