代码之家  ›  专栏  ›  技术社区  ›  Alex

powershell正在加载模块内的模块[作用域]

  •  2
  • Alex  · 技术社区  · 7 年前

    解决方案:


    Import-Module (Join-Path $PSScriptRoot $_.FileName) -Verbose -Global
    

    添加 -Global 在我的模块中切换,使所有函数都可以在自己的上下文之外访问。


    我有一个powershell模块( ConfigModule.psm1 )我已经创造了我曾经和我的 config.xml .

    当我将模块包含到测试脚本中时,一切都很好。

    我调用一个名为 Import-ConfigModules 它为( type="Module" )并为( type="script" )来自 XML 价值 Get-Item... .

    这就是我的负载层次结构:

    1. 测试脚本导入 配置模块.psm1
    2. 配置模块.psm1 导入同一目录中的其他模块
    3. 其他模块具有不同的功能。

    问题:

    在调用不同文件中的模块函数时,模块会按照我使用的方式加载 -Verbose 切换到测试,我可以访问变量 我无法访问功能 not recognized .

    这是导入模块范围问题吗?

    如果是,如何将模块传递到我的测试脚本上下文中?


    configmodule.psm1>导入configmodules
    Function Import-ConfigModules {
        param([String]$Path)
        $modules = Get-ConfigModules -Path $Path
    
        # Iterate by FileType
        $modules.Keys | % {
    
            switch($modules[$_]) {
                {$_.FileType -eq "module"} {
                    # If Module exists, load, else find similar modules=
                    if(Test-Path (Join-Path $PSScriptRoot $_.FileName)) {
    
                        Import-Module (Join-Path $PSScriptRoot $_.FileName) -Verbose
                        # Test if module was loaded
                        if(Get-Module $_.VariableName) {
                            Write-Host "Module [Loaded]: " ($_.FileName) -ForegroundColor Green
                        }
                        else {
                            Write-Host "Module [Error]: Could not import module - " ($_.FileName) -ForegroundColor Green
                        }
    
                    }
                    else {
                        Write-Host "Module [Missing]: $($_.FileName).`r`nFound similar: " -ForegroundColor Yellow -NoNewline
                        Get-SimilarFile `
                            -Path $PSScriptRoot `
                            -Name $_.FileName
                    }
                    break
                }
                {$_.FileType -eq "script"} {
                    if(Test-Path (Join-Path $PSScriptRoot $_.FileName)) {
                        Write-Host "Script [Loaded]: " ($_.FileName) -ForegroundColor Green
    
                        # Create variables dynamically
                        Set-Variable -Name "$($_.VariableName)" -Scope Global -Value (Get-Item -Path (Join-Path $PSScriptRoot $_.FileName))
                    }
                    else {
                        Write-Host "Script [Missing]: $($_.FileName).`r`nFound similar: " -ForegroundColor Yellow -NoNewline
                        Get-SimilarFile `
                            -Path $PSScriptRoot `
                            -Name $_.FileName
                    }
                    break
                }
                default { Write-Warning "$($_.FileName) : Bad FileType definition. {FileType: $($_.FileType)}" }
            }
            Write-Host
        }
    }
    

    这是一个样品 Config.xml :


    <Modules>
      <SFModule filename="sfmodule.psm1" varname="SFModule" type="module" sha256="A1B6AE739F733DD8C75AD2778D395953BF2F6EF61B4240B014C446394B87E881" />
      <ETSModule filename="etsmodule.psm1" varname="ETSModule" type="module" sha256="46FD0887DDFBDD88FAECD173F41A448BC57E26CEE6FF40C32500E5994284F47B" />
      <WPFModule filename="wpfmodule.psm1" varname="WPFModule" type="module" sha256="1BEC1B84778148570774AB4E51126A8FB4F2BA308D5BA391E3198805CC13DB2B" />
      <GetInt filename="getint.ps1" varname="getInt" type="script" sha256="FBAF335E80623F26B343939B3D44B9C847388D3ADB351EAF551C8A35D75DF876" />
      <GetDom filename="getdom.ps1" varname="getDom" type="script" sha256="70F4DA69E99DA6157D8DFB60368D65B132504114FF6F6FACDE351FF0C8B8F820" />
      <CopyResult filename="copy_result.ps1" varname="copyResult" type="script" sha256="DCA12BCF8FAC6F52C6E4721DFA2F77FC78183681F6945CB7FCD2010CA94A86C3" />
    </Modules>
    
    1 回复  |  直到 7 年前
        1
  •  1
  •   Alex    7 年前

    有效的解决方案:

    Import-Module (Join-Path $PSScriptRoot $_.FileName) -Verbose -Global

    通过添加 -Global 切换到 Import-Module 它将模块导入到全局范围中,允许外部脚本访问其功能。

    推荐文章