遍历备份 Chrome | Edge 浏览器插件目录

遍历指定的浏览器插件目录,读取每个插件的配置文件以提取真实的插件名称版本号 ,然后将它们批量复制备份 到一个指定的目录中,并最终生成一份包含详细信息的 .csv 清单文件。

PowerShell 插件批量梳理与备份脚本

可以直接打开 PowerShell 终端,将以下代码复制并粘贴执行;或者将其保存为 .ps1 文件运行。

复制代码
# ==========================================
# 浏览器配置区
# ==========================================
# 目标浏览器: 选择 "Edge" 或 "Chrome"
$browser = "Edge" 

# 备份目标路径: 这里默认设置在 D 盘的临时下载目录,你可以按需修改
$backupDir = "D:\Download\Temp\BrowserExtensionsBackup" 

# ==========================================
# 脚本执行区
# ==========================================
# 1. 确定浏览器的本地扩展路径
$basePath = if ($browser -eq "Chrome") {
    "$env:LOCALAPPDATA\Google\Chrome\User Data\Default\Extensions"
} else {
    "$env:LOCALAPPDATA\Microsoft\Edge\User Data\Default\Extensions"
}

if (!(Test-Path $basePath)) {
    Write-Warning "未找到 $browser 的默认插件目录: $basePath"
    Write-Warning "如果你使用了多配置(Profile),请手动修改 `$basePath 路径。"
    return
}

# 2. 创建备份主目录
if (!(Test-Path $backupDir)) {
    New-Item -ItemType Directory -Force -Path $backupDir | Out-Null
}

$extensions = @()

Write-Host "开始扫描 $browser 插件目录..." -ForegroundColor Cyan

# 3. 遍历插件 ID 文件夹
Get-ChildItem -Path $basePath -Directory | ForEach-Object {
    $extId = $_.Name
    
    # 遍历具体的版本号文件夹
    Get-ChildItem -Path $_.FullName -Directory | ForEach-Object {
        $versionDir = $_.FullName
        $version = $_.Name
        $manifestPath = Join-Path -Path $versionDir -ChildPath "manifest.json"

        if (Test-Path $manifestPath) {
            try {
                # 读取 manifest.json,使用 UTF8 防止中文名称乱码
                $manifest = Get-Content -Path $manifestPath -Raw -Encoding UTF8 | ConvertFrom-Json
                $extName = $manifest.name

                # 处理多语言国际化名称 (以 __MSG_ 开头的变量)
                if ($extName -match "^__MSG_") {
                    $extName = "[需手动核对] 国际化名称插件 ($extId)"
                }

                # 将信息存入对象数组
                $extensions += [PSCustomObject]@{
                    Browser = $browser
                    Name    = $extName
                    Version = $version
                    ID      = $extId
                    Path    = $versionDir
                }

                # 4. 执行备份操作 (按 "插件名称_版本号" 的格式重命名备份文件夹,并过滤非法路径字符)
                $safeName = $extName -replace '[\\/:*?"<>|]', '_'
                $targetPath = Join-Path -Path $backupDir -ChildPath "${safeName}_${version}"
                
                if (!(Test-Path $targetPath)) {
                    Copy-Item -Path $versionDir -Destination $targetPath -Recurse -Force
                }
            } catch {
                Write-Warning "解析 JSON 失败: $manifestPath"
            }
        }
    }
}

# 5. 输出结果与导出清单
$extensions | Format-Table -Property Name, Version, ID -AutoSize

$csvPath = Join-Path -Path $backupDir -ChildPath "ExtensionsList.csv"
$extensions | Export-Csv -Path $csvPath -NoTypeInformation -Encoding UTF8

Write-Host "=====================================" -ForegroundColor Green
Write-Host "扫描与备份已完成!" -ForegroundColor Green
Write-Host "插件源码已备份至: $backupDir" 
Write-Host "详细清单已导出至: $csvPath"
Write-Host "=====================================" -ForegroundColor Green
相关推荐
WiChP3 小时前
【V0.1B4】从零开始的2D游戏引擎开发之路
前端·javascript·游戏引擎
意法半导体STM323 小时前
【官方原创】STM32CubeProgrammer与STM32 Bootloader连接全流程实战指南 LAT1631
开发语言·前端·javascript·stm32·单片机·嵌入式硬件
薛定谔的悦3 小时前
《储能系统中的故障定位》
java·服务器·前端
慧一居士3 小时前
Vue项目中使用的首选的依赖库如VueUse等,使用场景和使用示例介绍
前端·vue.js
带娃的IT创业者3 小时前
WeClaw-TTS 语音合成实战:pyttsx3 本地引擎与 Edge-TTS 云服务的混合架构.md
前端·tts·ai智能体·openclaw·weclaw
鹏程十八少3 小时前
5.Android 如何用腾讯Shadow在双11电商场景的完整复盘(实战2年),实现热修复(全网最详细实战案例)
android·前端·面试
wl85113 小时前
SAP HCM 公积金超过上限后的计税方案
前端·html
二月夜3 小时前
Vue项目打包为WAR文件部署Tomcat完整指南
前端·vue.js·tomcat
终端鹿3 小时前
Vue3 核心 API 完结篇:toRaw / markRaw / shallowReactive / shallowRef 等进阶响应式 API 详解
前端·javascript·vue.js