Import-PowerShellDataFile
從 .PSD1
檔案匯入值,而不叫用其內容。
語法
Import-PowerShellDataFile
[-Path] <String[]>
[-SkipLimitCheck]
[<CommonParameters>]
Import-PowerShellDataFile
[-LiteralPath] <String[]>
[-SkipLimitCheck]
[<CommonParameters>]
Description
Cmdlet Import-PowerShellDataFile
會從檔案中 .PSD1
定義的哈希表安全地匯入索引鍵/值組。 值可以使用 檔案的內容匯入 Invoke-Expression
。
不過,執行 Invoke-Expression
檔案中包含的任何程序代碼。 這可能會產生不必要的結果,或執行不安全的程序代碼。 Import-PowerShellDataFile
匯入數據,而不叫用程序代碼。 根據預設,有 500 個密鑰限制,但您可以使用 SkipLimitCheck 參數略過此限制。
範例
範例 1:從 PSD1 擷取值
這個範例會擷取儲存在檔案內之哈希表中的 Configuration.psd1
索引鍵/值組。 Get-Content
用來顯示檔案的內容 Configuration.psd1
。
Get-Content .\Configuration.psd1
$config = Import-PowerShellDataFile .\Configuration.psd1
$config.AllNodes
@{
AllNodes = @(
@{
NodeName = 'DSC-01'
}
@{
NodeName = 'DSC-02'
}
)
}
Name Value
---- -----
NodeName DSC-01
NodeName DSC-02
參數
-LiteralPath
要匯入之檔案的路徑。 路徑中的所有字元都會被視為常值。 不會處理通配符。
類型: | String[] |
別名: | PSPath, LP |
Position: | 0 |
預設值: | None |
必要: | True |
接受管線輸入: | True |
接受萬用字元: | False |
-Path
要匯入之檔案的路徑。 允許通配符,但只會匯入第一個相符的檔案。
類型: | String[] |
Position: | 0 |
預設值: | None |
必要: | True |
接受管線輸入: | False |
接受萬用字元: | True |
-SkipLimitCheck
根據預設 Import-PowerShellDataFile
,只會從檔案匯入 500 個 .psd1
金鑰。 使用 SkipLimitCheck 匯入超過 500 個密鑰。
類型: | Switch |
Position: | 0 |
預設值: | False |
必要: | False |
接受管線輸入: | False |
接受萬用字元: | False |
輸出
此 Cmdlet 會將檔案中的數據當做哈希表傳回。