有办法做到这一点吗?
还是我必须手动从登记处取每一条记录?
有办法做到这一点吗?
还是我必须手动从登记处取每一条记录?
当前回答
当我尝试其他解决方案时,我得到了这个错误:
Registry editing has been disabled by your administrator.
我说,真糟糕!
我把下面的powershell脚本放在一起,用于导出和导入PuTTY设置。导出的文件是一个windows .reg文件,如果您有权限,将干净地导入,否则请使用import。Ps1加载它。
警告:像这样打乱注册表是一个坏主意™,我真的不知道我在做什么。使用以下脚本的风险由您自己承担,并准备让您的IT部门重新对您的机器进行映像,并就您正在做的事情向您提出令人不舒服的问题。
在源计算机上:
.\export.ps1
在目标机器上:
.\import.ps1 > cmd.ps1
# Examine cmd.ps1 to ensure it doesn't do anything nasty
.\cmd.ps1
export.ps1
# All settings
$registry_path = "HKCU:\Software\SimonTatham"
# Only sessions
#$registry_path = "HKCU:\Software\SimonTatham\PuTTY\Sessions"
$output_file = "putty.reg"
$registry = ls "$registry_path" -Recurse
"Windows Registry Editor Version 5.00" | Out-File putty.reg
"" | Out-File putty.reg -Append
foreach ($reg in $registry) {
"[$reg]" | Out-File putty.reg -Append
foreach ($prop in $reg.property) {
$propval = $reg.GetValue($prop)
if ("".GetType().Equals($propval.GetType())) {
'"' + "$prop" + '"' + "=" + '"' + "$propval" + '"' | Out-File putty.reg -Append
} elseif ($propval -is [int]) {
$hex = "{0:x8}" -f $propval
'"' + "$prop" + '"' + "=dword:" + $hex | Out-File putty.reg -Append
}
}
"" | Out-File putty.reg -Append
}
import.ps1
$input_file = "putty.reg"
$content = Get-Content "$input_file"
"Push-Location"
"cd HKCU:\"
foreach ($line in $content) {
If ($line.StartsWith("Windows Registry Editor")) {
# Ignore the header
} ElseIf ($line.startswith("[")) {
$section = $line.Trim().Trim('[', ']')
'New-Item -Path "' + $section + '" -Force' | %{ $_ -replace 'HKEY_CURRENT_USER\\', '' }
} ElseIf ($line.startswith('"')) {
$linesplit = $line.split('=', 2)
$key = $linesplit[0].Trim('"')
if ($linesplit[1].StartsWith('"')) {
$value = $linesplit[1].Trim().Trim('"')
} ElseIf ($linesplit[1].StartsWith('dword:')) {
$value = [Int32]('0x' + $linesplit[1].Trim().Split(':', 2)[1])
'New-ItemProperty "' + $section + '" "' + $key + '" -PropertyType dword -Force' | %{ $_ -replace 'HKEY_CURRENT_USER\\', '' }
} Else {
Write-Host "Error: unknown property type: $linesplit[1]"
exit
}
'Set-ItemProperty -Path "' + $section + '" -Name "' + $key + '" -Value "' + $value + '"' | %{ $_ -replace 'HKEY_CURRENT_USER\\', '' }
}
}
"Pop-Location"
不好意思,代码不是很习惯,我不是很熟悉Powershell。欢迎改进!
其他回答
m0nhawk的答案在Windows 10上对我不起作用——它需要更高的命令提示符,并且拒绝发出文件。
这是可行的,而且不需要抬高:
reg export HKEY_CURRENT_USER\Software\SimonTatham\PuTTY putty.reg
这比上面所述的导入注册表导出要容易得多。 + 简单:
右键单击文件,然后 选择“合并”
在win7 Pro上工作得很出色。
我使用putty连接管理器,您可以在其中创建会话数据库。复制并导入该数据库到其他计算机很容易。
请看这个便利指南
对于那些需要从离线注册表文件中导入Putty的人,例如,当你从崩溃的系统中恢复或简单地移动到新机器并从旧驱动器中抓取数据时,还有一个解决方案值得一提:
http://www.nirsoft.net/utils/registry_file_offline_export.html
这个伟大而免费的控制台应用程序将导出整个注册表或仅导出特定的注册表项。在我的情况下,我只是将注册表文件从旧驱动器复制到与导出工具相同的目录,然后我使用以下命令和语法在CMD窗口以管理员身份运行:
RegFileExport.exe NTUSER.DAT putty。reg”HKEY_CURRENT_USER \ Software \ SimonTatham”
在导入.reg文件并启动Putty之后,一切都就绪了。简单高效。
如果你像我一样,安装了新的Windows,只有在你记得putty会话之后,你仍然可以导入它们,如果你有旧的Windows硬盘驱动器或至少备份了旧的“home”目录(C:\Users\<user_name>)。
在这个目录下应该有NTUSER.DAT文件。它在默认情况下是隐藏的,所以你应该在Windows资源管理器中启用隐藏文件或使用其他文件浏览器。该文件包含旧Windows注册表的HKEY_CURRENT_USER分支。
要使用它,您需要在新的Windows上打开regedit,并选择HKEY_USERS键。
然后选择File -> Load Hive…并找到旧Windows安装的“home”目录。在这个目录下应该有NTUSER.DAT文件。它在默认情况下是隐藏的,所以,如果你没有启用显示隐藏文件在你的Windows资源管理器属性,那么你可以手动输入文件名到“Load Hive”对话框的文件名输入框,然后按enter。然后在下一个对话框窗口中输入一些键名,将旧的注册表加载到其中。例如tmp。
旧注册表的HKEY_CURRENT_USER分支现在应该可以在当前注册表的HKEY_USERS\tmp分支下访问。
现在将HKEY_USERS\tmp\Software\SimonTatham分支导出到putty中。reg文件,在你最喜欢的文本编辑器中打开这个文件,并用HKEY_CURRENT_USER替换所有HKEY_USERS\tmp字符串。现在保存.reg文件。
现在可以通过双击将该文件导入到当前的Windows注册表中。参见m0nhawk的回答如何做到这一点。
最后,在注册表编辑器中选择HKEY_USERS\tmp分支,然后选择File -> Unload Hive…并确认该操作。