在 PowerShell 中检查 IEnumerable 是否为空

2023-12-10

是否有本地 PowerShell 方法来测试,如果IEnumerable是空的?

我知道我可以打电话Linq.Enumerable.Any像这样:

[Linq.Enumerable]::Any($enumeration)

但我希望有一种更本土化的方式。


很遗憾,noWindows PowerShell 中的 PowerShell 原生方式/自 PowerShell (Core) v7.2 起,同时[Linq.Enumerable]::Any()至少是concise, 它可以break在各种场景和不懒惰地操作在 PowerShell 中:

# These invocations with various *PowerShell* enumerables all FAIL with
# 'Cannot find an overload for "Any" and the argument count: "1"'
foreach ($enumerable in 1.5, $null, (& {}), (1,2,3)) {
  [Linq.Enumerable]::Any($enumerable) # !! BREAKS
}

# However, it does work with arrays that are *explicitly typed*.
[Linq.Enumerable]::Any([int[]] (1, 2)) # -> $true
  • Now, 1.5, $null and & {}do not实施[IEnumerable] ([System.Collections.IEnumerable]或通用对应物),但是在 PowerShell 的世界里一切是可枚举的, even scalars and $null,但后者仅在pipeline,不与foreach。值得注意的例外是“collection null”值,又名“AutomationNull”,其唯一目的是表明存在nothing枚举(因此你可以认为,作为一种特殊的枚举情况,它should实施[IEnumerable]) - see 这个答案.

  • 然而,1, 2, 3 does实施[IEnumerable]:它是一个常规的 PowerShell 数组类型[object[]];虽然你可以用 - 奇怪的是 - 显式解决这个特殊情况[object[]]强制转换,这显然不是一个通用的解决方案,因为有可能转换为array强制完整枚举 - 请参阅底部部分以获取更多信息。

  • 未来将更好的 LINQ 集成到 PowerShell 中是主题GitHub 问题 #2226.

一个强大但晦涩且非懒惰的仅 PowerShell 原生功能的解决方案处理上述所有情况的方法是(PSv4+):

# Returns $true if $enumerable results in enumeration of at least 1 element.
# Note that $null is NOT considered enumerable in this case, unlike 
# when you use `$null | ...`
$haveAny = $enumerable.Where({ $true }, 'First').Count -ne 0

# Variant with an example of a *filter* 
# (Find the first element that matches a criterion; $_ is the object at hand).
$haveAny = $enumerable.Where({ $_ -gt 1000 }, 'First').Count -ne 0

以上是:

  • 不太明显,因此很难记住。
  • 更重要的是,这种方法不能利用pipeline,这就是 PowerShell 的实现方式惰性(按需)枚举, and 此限制适用于all .NET 方法调用, 包括[Linq.Enumerable]::Any().

也就是说,可枚举 - 因为method正在被召唤 - 必须是表达,并且当 PowerShell 使用命令作为表达式(包括分配给变量)时,它运行命令直至完成并且隐含地收集所有输出 in an [object[]]- 类型数组。


因此,一个lazy本机 PowerShell 解决方案需要使用pipeline,形式为a 假想 Test-Any cmdlet, which:

  • 通过接收输入pipeline, in a 流媒体时尚(逐个对象)。
  • outputs $true如果接收到至少一个输入对象。

Note: The examples use $enumerable as pipeline input for brevity, but only with actual calls to PowerShell commands, say , Get-ChildItem, would you get streaming (lazy) behavior.

# WISHFUL THINKING
$haveAny = $enumerable | Test-Any

# Variant with filter.
$haveAny = $enumerable | Test-Any { $_ -gt 100 }

The 无条件的(无过滤器)变体Test-Any可以通过有效地模拟Select-Object -First 1

$haveAny = 1 -eq ($enumerable | Select-Object -First 1).Count

Select-Object可以利用异常类型来短路管道输入private在 Windows PowerShell 和 PowerShell (Core) v7.2 中。也就是说,有目前用户代码无法按需停止管道,其中Test-Anycmdlet 需要执行以下操作才能有效工作(以防止完全枚举):

  • 可以找到长期存在的功能请求在 GitHub 问题 #3821 中.

  • An 高效、懒惰Test-Any通过使用来解决该限制的实现privatePowerShell类型可以在这个答案,礼貌地PetSerAl;除了依赖私有类型之外,您还会遭受按需编译性能损失first在会话中使用。

  • 与此相类似,GitHub 问题 #13834要求.Where()数组法的高级功能被引入其基于管道的等效项,Where-Objectcmdlet(其内置别名是where),这将允许一个解决方案,例如:

    # WISHFUL THINKING
    $haveAny = 1 -eq ($enumerable | where { $_ -gt 1000 } -First).Count
    

可选阅读:使用[Linq.Enumerable]::Any($enumerable)使用 PowerShell 数组

1, 2, 3(通常表示为@(1, 2, 3),但是这是不必要的)是一个实例[object[]]array,PowerShell 的默认数组类型。

我不清楚为什么你不能将这样的数组传递给.Any() as-is,鉴于它确实可以与显式强制转换一起使用同类型: [Linq.Enumerable]::Any([object[]] (1,2,3)) # OK

最后,用一个构造的数组specific类型也可以按原样传递:
$intArr = [int[]] (1, 2, 3); [Linq.Enumerable]::Any($intArr) # OK

如果有人知道为什么你不能使用[object[]]在此上下文中的数组没有明确的强制转换是否有充分的理由,请告诉我们。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

在 PowerShell 中检查 IEnumerable 是否为空 的相关文章

随机推荐

  • UI 之外用于 javascript 链接的闪亮模块命名空间

    我正在尝试使用闪亮的模块来重用 UI 和服务器代码来呈现共享相同演示文稿的三个不同数据集 在 UI 服务器代码之外使用基于 JavaScript 的模态弹出链接创建时 在处理命名空间时遇到了一些挑战 这是我的非工作应用程序代码 librar
  • 大括号扩展和参数扩展的顺序

    StackOverflow 上的常见比喻bash is 为什么不x 99 echo 1 x work 答案是 因为大括号在参数 变量之前展开 因此 我认为应该可以使用单个变量来扩展多个变量 和一个支架 我预计a 1 b 2 c 3 echo
  • 如何使 FlowLayout 包裹在其 JSplitPane 中?

    我编写此代码示例是为了说明我的程序遇到的问题 我希望能够将 JSplitPane 的滑块向左滑动 超出按钮的边缘 压缩 JPanel 并使 FlowLayout 将按钮包装到第二行 相反 JSplitPane 不允许我将滑块移过屏幕上最右边
  • 反序列化时的备用属性名称

    关于这个问题 使用 Json net 序列化时如何更改属性名称 当然 很好 但是我可以把蛋糕吃掉吗 我正在寻找一种令人赏心悦目的方式 为属性提供一个备用名称 使得字符串可以包含其中之一 就像是 BetterJsonProperty Prop
  • Android 构建错误

    当尝试在 Eclipse 中构建我的应用程序时 我遇到了这些错误 当编译器警告我我的 project 文件丢失时 事情开始走下坡路 然后我尝试修复该项目 现在收到以下错误 构建期间发生错误 在项目 net learn2develop Lay
  • 如何关闭 dropwizard 应用程序?

    我正在尝试使用 dropwizard 提出一个微服务 该文档讲述了如何启动应用程序 但没有提及如何优雅地终止它 例如 apache tomcat 都有启动and关闭脚本 那么有谁知道除了按之外如何终止 dropwizard 应用程序Ctrl
  • Python如何通过多重继承传递__init__参数

    我有这段代码 显示了经典的菱形图案 class A def init self x print A x class B A def init self x print B x super init b class C A def init
  • 如何从react调用存储过程

    我得到了一个已经用 ASP NET 开发的网站 我需要在 React 中开发同样的东西 下面是在 net 中编写的代码 用于在用户单击登录时调用存储过程 Dal objDal new Dal DataSet ds objDal ByText
  • c 编程 shmat() 权限被拒绝

    当我运行我的代码时遇到问题 我的 shmat 失败并且打印权限被拒绝 我在谷歌上搜索了如何解决它 但我不能 我的代码如下 include
  • AWS EMR 5.11.0 - Spark 上的 Apache Hive

    我正在尝试在 AWS EMR 5 11 0 上设置 Apache Hive on Spark Apache Spark 版本 2 2 1 Apache Hive 版本 2 3 2 纱线日志显示以下错误 18 01 28 21 55 28 错
  • C++ 数字加负数

    所以我只是练习编写斐波那契数列的动态解决方案 该解决方案将返回第 n 个斐波那契数 但我不断遇到一个我不太明白的问题 我得到两个正数加上一个负数 Code int fib int n vector
  • 使用 $window 配置 AngularJS 路由到深层路径

    我有一个 Rails 应用程序 其中有一些复杂的路由 我的 Angular 应用程序存在于深层 URL 中 例如 quizzes 1 我希望通过将 window 注入到我的路由配置中 然后嗅探 window location pathNam
  • ImportError:没有名为 sip 的模块(python2.7 PyQt4)

    我目前使用的是 Ubuntu 18 04 LTS 我正在尝试安装一个需要 PyQt4 和 QtWebKit 的程序 因此需要手动安装 因为 QtWebKit 已从 PyQt4 中排除 我下载了 sip 4 19 12 4 19 14 安装
  • 通过用逗号分隔的关键字突出显示文本

    我想用逗号分隔文本 即关键字如下 keyword1 keyword2 keyword3 keyword4 如何为每个以逗号分隔的关键字提供黑色样式元素 是否有捷径可寻 文本总是动态的 所以我永远不知道这些关键字到底是什么以及有多少 因此每个
  • 如何在tomcat中设置org.apache.tomcat.util.digester.EnvironmentPropertySource

    我想通过 Kubernetes 为 tomcat 中的 server xml 设置环境变量 这是我的部署 yaml apiVersion v1 kind Pod metadata name tomcat test pod env name
  • 如何使用 Greasemonkey 自动提交表单?

    我正在尝试使用greasemonkey 自动提交表单 但我不知道如何使用此按钮来完成此操作 该按钮似乎具有以下属性 a class blue button href javascript void 0 onclick Form submit
  • 标签栏中的自定义字体

    Hey 有没有办法将选项卡栏的字体设置为例如黑板 我已经看到了字体大小的问题 并尝试使用字体 但循环无法解决 如果无法使用自定义字体 是否可以删除所有文本并使选项卡栏的项目覆盖整个选项卡 或者我可以以某种方式将 imageView 放在选项
  • 使用map迭代两个数组

    目前在 React 中 我正在使用array map function text index 迭代数组 但是 我如何使用 map 同时迭代两个数组 EDIT var sentenceList sentences map function t
  • 如何设置共享默认文件夹的 Outlook 子文件夹?

    我正在尝试从共享 Outlook 收件箱的子文件夹中提取信息 当我将文件夹设置为共享收件箱 olFolderInbox 时 代码可以完美运行 但是 当我将其设置为子文件夹时 代码有时会失败 我确保子文件夹名称是正确的 这是我的代码 Dim
  • 在 PowerShell 中检查 IEnumerable 是否为空

    是否有本地 PowerShell 方法来测试 如果IEnumerable是空的 我知道我可以打电话Linq Enumerable Any像这样 Linq Enumerable Any enumeration 但我希望有一种更本土化的方式 很