4

我正在尝试使用InitialSessionState.ImportPSModule以导入 Powershell 模块。

我有兴趣知道模块的导入是否由于任何原因(例如找不到文件等)而失败。将此类代码放在 try 块中不会在失败的情况下引发异常,并且该函数似乎会静默失败并在无法导入模块时继续。

如果导入失败,有没有办法在代码中发出警报?

我正在尝试执行以下操作。在下面的代码中,模块“TestModule1234”不存在。catch 块不会捕获异常。

注意:这只是原型测试代码,所以请忽略任何与生产代码相关的违规行为。

try
{
    //Initializing the PowerShell runspace
    InitialSessionState psSessionInitialState = InitialSessionState.CreateDefault();


    LogFile.Log("Importing Module TestModule1234");
    psSessionInitialState.ImportPSModule(new[] { "TestModule1234" });

    LogFile.Log("Creating Powershell Runspace");
    m_PoshRunspace = RunspaceFactory.CreateRunspace(psSessionInitialState);
}
catch (System.Exception ex)
{
    LogFile.Log("Failed to create a Powershell Runspace");
    LogFile.Log(ex.ToString());
    throw;
}
4

1 回答 1

7

由于某些原因,缺少模块不会被视为致命错误。但它们仍然是重新编码的错误。为了解决问题,请执行以下操作:

  1. 通过 .打开你的运行空间Open()。仍然在 try 块中执行此操作以捕获其他异常,它们是可能的,我在实践中遇到过这种情况。
  2. 获取标准错误列表 ( $Error) 并在打开后分析特定的“缺少模块”错误或其他错误。

这是 PowerShell 中仅使用 .NET 方法的工作示例,因此它被直译为 C#。此脚本不会失败(不会引发异常),但会显示作为变量获得的错误 Error

$psSessionInitialState = [System.Management.Automation.Runspaces.InitialSessionState]::CreateDefault();

"Importing Module TestModule1234"
$psSessionInitialState.ImportPSModule(@("TestModule1234"))

"Creating PowerShell Runspace"
$PoshRunspace = [System.Management.Automation.Runspaces.RunspaceFactory]::CreateRunspace($psSessionInitialState)

"Opening PowerShell Runspace"
$PoshRunspace.Open()

"Getting Runspace Error"
$PoshRunspace.SessionStateProxy.PSVariable.GetValue('Error')

输出

导入模块 TestModule1234 创建 Powershell 运行空间 打开 Powershell 运行空间 获取运行空间错误 Import-Module:未加载指定的模块“TestModule1234”,因为在任何模块目录中都找不到有效的模块文件。+ CategoryInfo : ResourceUnavailable: (TestModule1234:String) [Import-Module], FileNotFoundException + FullyQualifiedErrorId : Modules_ModuleNotFound,Microsoft.PowerShell.Commands.ImportModuleCommand

于 2012-12-18T15:01:19.837 回答