【问题标题】:Seemingly random errors when loading powershell script加载 powershell 脚本时出现看似随机的错误
【发布时间】:2020-09-11 12:42:28
【问题描述】:

过去几个月我一直在编写一个脚本,该脚本可以自动执行我们正在使用的系统的配置过程。主脚本导入其他所需的“实用程序”脚本并运行主循环。它导入的脚本之一是处理表单创建、显示等的表单脚本。脚本有两个版本——一个用于笔记本电脑,一个用于我们指定为服务器的台式机。在为笔记本电脑版本开发时,我没有遇到与我将要描述的问题相关的问题。然而,当第一次在我们的测试机器上测试服务器版本时,我开始遇到一些奇怪的错误。奇怪的是,它总是不一致。有时没有错误,有时有 2 到 4 个错误。我认为还需要注意的是,从 powershell ISE 运行脚本时,我不会收到这些错误,只有在通过加载脚本的批处理文件运行时才会出现这些错误。

我收到的一些错误如下:

Exception setting "Size": "Cannot convert the "System.Drawing.Size get_MinimumSize()" value of type "System.Reflection.RuntimeMethodInfo" to type "System.Drawing.Size"."

Exception setting "Margin": "Cannot convert the "System.Drawing.Size" value of type "System.Management.Automation.Language.TypeName" to type "System.Windows.Forms.Padding"."

这些特定错误来自更改 System.Windows.Forms.ComboBox 对象设置(大小和边距值)的行。

由于我在 Powershell 方面的经验有限,我将其范围缩小到我认为正在发生的事情。在脚本的开头,System.Windows.FormsSystem.Drawing 类与 Add-Type -AssemblyName... 行一起添加。这是我在几个教程中看到的能够实际创建和使用 .NET 表单的内容。只是基于大部分猜测,我只是添加了一个 5 秒的 Start-Sleep 命令,看看会发生什么。瞧,这似乎解决了错误。至少,当我尝试从 .bat 文件运行大约 10-20 次时,我没有收到错误。

我的主要问题是实际发生了什么?我想确保这些错误不会再次出现,我不相信我实施的“修复”将确保这一点。这样做似乎没有意义,因为如果它实际上是类未加载的问题,我会假设/希望Powershell会产生某种错误。我也想知道为什么我从来没有看到这些错误在笔记本电脑版本上运行脚本。我不知道从哪里开始查看两者之间的差异会导致此错误,但我仍然很感兴趣

【问题讨论】:

  • $form.ShowDialog() 之后完成时,您会执行 .Dispose() 表单,不是吗?如果没有,重复显示表格而不处理它会导致问题
  • ISE 开发工作适合此类问题,因为其中定义的大多数变量将持续到 ISE 关闭。为确保不会发生这种情况,您可以每隔一小时左右打开新的 ISE 窗口,以尝试早点发现此类错误。 Add-type 命令是同步的。在Add-Type 完成之前,PowerShell 不会移动到下一行。延迟听起来像一个红鲱鱼(不是真正的错误)
  • @Theo 是的,我愿意。
  • 请向我们展示您的代码的相关部分。您显示的错误可能有多种原因,但如果没有代码,则无法查明。

标签: .net powershell


【解决方案1】:

如果可能的话,到目前为止,我们必须假设很多代码(或部分代码),这可能不是真的。

无论如何,根据我的经验,这是我的想法“无法转换......”错误。尝试将值分配给其他类型的特定变量时,我也遇到了此错误。

我的解决方案是:在分配新值之前,我删除了 Remove-Variable Size 之类的变量(注意:变量名前面没有 $!)

另一种解决方案可能是指定分配类型,例如[System.Reflection.RuntimeMethodInfo]$Size = WhateverYourCodeIs

【讨论】:

  • 我在原始帖子中提到的错误行非常简单。其中之一是$cboVariable.Size = $cboSize$cboSize 被设置为 System.Drawing.Size 对象,因为它被大量使用。当表单被清理时,表单本身和它的所有字段都会被处理掉。我得试试你的方法
猜你喜欢
  • 1970-01-01
  • 2012-01-30
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多