我想编辑INI文件的值。我使用这个脚本,但它给了我错误。
Get-IniContent : The term 'Get-IniContent' is not recognized as the name of a
cmdlet, function, script file, or operable program.
Run Code Online (Sandbox Code Playgroud)
我的 INI 文件的内容位于c:\Users\file.ini:
[XXX]
AB=23
BC=34
Run Code Online (Sandbox Code Playgroud)
用于读取和更新脚本的内容:
# Read the content of an *.ini file into a (nested) hashtable.
$ini = Get-IniContent "C:\Users\file.ini"
# Update the 'AB' entry in section [XXX] in-memory.
$ini["XXX"]["AB"] = "12"
# Write the updated content back to the *.ini file.
$ini | Out-IniFile -FilePath "C:\Users\file.ini -Force"
Run Code Online (Sandbox Code Playgroud)
JeroenMostert在评论中提供了关键点:
从 v7.2.x 开始,PowerShell 没有用于*.ini处理 INI 文件 ( )的内置 cmdlet ,尽管GitHub 问题 #9035 中正在讨论引入此类 cmdlet 。
Get-IniContent和是第三方模块Out-IniFile附带的高级功能(类似 cmdlet 的功能),可从 PowerShell Gallery 获取。PSIni
在 PowerShell v5 或更高版本(附带PowerShellGet模块[1] )中,安装非常简单:
Install-Module -Scope CurrentUser PsIni
Run Code Online (Sandbox Code Playgroud)
如果省略-Scope CurrentUser,您将为所有用户安装该模块,但这样做需要以管理权限运行。
在$PSModuleAutoLoadingPreference默认情况下(未设置),该模块会根据需要自动加载到尝试调用模块命令之一的会话中,例如Get-IniContent.
这是一个完整的、独立的示例,用于练习该PsIni模块的核心功能:
*.ini使用Out-IniFile, 从嵌套有序哈希表中从头开始创建示例文件。Get-IniContent到(新的)嵌套有序哈希表中Out-IniFile注意:假设Install-Module可用,即模块已安装,并且运行的计算机在线并允许从https://www.powershellgallery.com/PowerShellGet下载软件包。
# Import the PsIni module.
# If necessary, install it first, for the current user.
$ErrorActionPreference = 'Stop' # Abort, if something unexpectedly goes wrong.
try {
Import-Module PsIni
} catch {
Install-Module -Scope CurrentUser PsIni
Import-Module PsIni
}
# Create an ordered hashtable that is the in-memory representation of the
# sample *.ini file from the question, with a second section added.
$iniFileContent = [ordered] @{
# 'XXX' is the section name.
# The nested hashtable contains that section's entries.
XXX = [ordered] @{
# IMPORTANT:
# * The PsIni module only supports STRING values.
# * While you can assign values of different types in-memory, they are
# CONVERTED TO STRINGS with .ToString() and READ AS STRINGS later
# by Get-IniContent.
# * In v3+, PSIni now supports values in *.ini files that have
# embedded quoting - e.g., `AB = "23"` as a raw line - which is
# (sensibly) *stripped* on reading the values.
AB = '23'
BC = '34'
}
# Create a 2nd section, named 'YYY', with entries 'yin' and 'yang'
YYY = [ordered] @{
yin = 'foo'
yang = 'none'
}
}
# Use Out-IniFile to create file 'file.ini' in the current dir.
# * Default encoding is UTF-8 (with BOM in Windows PowerShell, without BOM
# in PowerShell Core)
# * Use -Encoding to override, but note that
# Get-IniContent has no matching -Encoding parameter, so the encoding you use
# must be detectable by PowerShell in the absence of explicit information.
# * CAVEAT: -Force is only needed if an existing file must be overwritten.
# I'm using it here so you can run the sample code repeatedly without
# failure, but in general you should only use it if you want to
# blindly replace an existing file - such as after having modified
# the in-memory representation of an *.ini file and wanting to
# write the modifications back to disk - see below.
$iniFileContent | Out-IniFile -Force file.ini
# Read the file back into a (new) ordered hashtable
$iniFileContent = Get-IniContent file.ini
# Modify the value of the [XXX] section's 'AB' entry.
$iniFileContent.XXX.AB = '12'
# Use the alternative *indexing syntax* (which is equivalent in most cases)
# to also modify the [YYY] section's 'yin' entry.
$iniFileContent['YYY']['yin'] = 'bar'
# Remove the 'yang' value from section [YYY]:
$iniFileContent.YYY.Remove('yang')
# Save the modified content back to the original file.
# Note that -Force is now *required* to signal the explicit intent to
# replace the existing file.
$iniFileContent | Out-IniFile -Force file.ini
# Double-check that modifying the values succeeded.
(Get-IniContent file.ini).XXX.AB # should output '12'
(Get-IniContent file.ini).YYY.yin # should output 'bar'
# Print the updated content of the INI file, which
# shows the updated values and the removal of 'yang' from [YYY].
"--- Contents of file.ini:"
Get-Content file.ini
Run Code Online (Sandbox Code Playgroud)
运行上述命令应该成功并输出以下内容,表明文件*.ini已成功创建、读回内存、修改并保存回磁盘:
12
bar
--- Contents of file.ini:
[XXX]
AB=12
BC=34
[YYY]
yin=bar
Run Code Online (Sandbox Code Playgroud)
[1] 您可以PowerShellGet按需安装 PowerShell 版本 3 和 4 - 请参阅https://www.microsoft.com/en-us/download/details.aspx?id=51451
| 归档时间: |
|
| 查看次数: |
10120 次 |
| 最近记录: |