如何用winget-cli管理Windows软件:从入门到自动化部署
你是否还在为Windows系统中软件的安装、更新和卸载流程繁琐而困扰?是否希望有一种工具能像Linux系统的apt或yum一样,通过命令行高效管理软件包?微软开发的winget-cli(Windows Package Manager)正是为解决这些问题而生,它让Windows软件管理变得简单、高效且可自动化。
一、快速部署winget环境
检查系统兼容性
在开始前,请确认你的系统满足基本要求:Windows 10 1809(内部版本17763)或更高版本。Windows Server 2019不支持,Windows Server 2022可实验性使用但需手动安装依赖。通过以下命令查看系统版本:
winver
注意:企业版Windows可能需要管理员权限才能安装Microsoft Store应用
三种安装方式对比
Microsoft Store安装(推荐)
通过Microsoft Store搜索"App Installer"获取最新稳定版,这种方式会自动接收更新。安装完成后,打开命令提示符验证:
winget --version
开发版本体验
想要尝试最新功能,可通过两种方式获取开发版本:加入Windows Insider计划或注册Windows Package Manager Insider计划。开发版本可能包含未稳定的新特性,适合技术尝鲜者。
手动安装包部署
从项目发布页面下载msixbundle包,通过以下命令手动安装:
Add-AppxPackage -Path .\Microsoft.DesktopAppInstaller_8wekyb3d8bbwe.msixbundle
💡 技巧:安装后若提示"命令未找到",检查%LOCALAPPDATA%\Microsoft\WindowsApps是否已添加到系统PATH环境变量
二、核心命令实战指南
搜索软件包资源
使用search命令查找需要的软件,支持按名称、ID或关键词搜索。例如查找Node.js开发环境:
winget search nodejs --source winget
| 参数 | 用途 | 示例值 |
|---|---|---|
-s, --source |
指定软件源 | winget, msstore |
-e, --exact |
精确匹配名称 | winget search "Node.js" -e |
--count |
限制结果数量 | winget search python --count 5 |
高效安装软件
安装软件时建议使用包ID以避免歧义,例如部署LTS版本的Node.js:
winget install OpenJS.NodeJS.LTS --silent
常用安装参数:
| 参数 | 用途 | 示例值 |
|---|---|---|
-v, --version |
指定版本号 | --version 18.17.1 |
--location |
自定义安装路径 | --location "D:\DevTools" |
--scope |
安装范围 | --scope user(当前用户) |
--silent |
静默安装模式 | 无交互安装 |
注意:部分软件可能需要管理员权限,此时需以管理员身份运行终端
批量更新系统软件
查看可更新的软件列表:
winget upgrade
更新指定软件或所有软件:
# 更新Visual Studio Code
winget upgrade Microsoft.VisualStudioCode
# 更新所有软件
winget upgrade --all --silent
管理软件源配置
查看当前配置的软件源:
winget source list
添加企业内部软件源:
winget source add -n CompanyRepo -u https://repo.example.com/winget
三、个性化配置与高级技巧
配置文件深度定制
通过配置文件settings.json可以定制winget的各种行为,使用以下命令打开配置文件:
winget settings
常用配置项示例:
{
"source": {
"autoUpdateIntervalInMinutes": 30
},
"visual": {
"progressBar": "rainbow"
},
"installBehavior": {
"preferences": {
"scope": "user",
"architectures": ["x64"]
}
}
}
详细配置参见设置文档
软件环境备份与迁移
导出当前已安装软件列表:
winget export -o D:\backup\installed_apps.json --include-versions
在新系统上恢复软件环境:
winget import -i D:\backup\installed_apps.json --silent
⚠️ 警告:导入操作会安装列表中的所有软件,请确保在新系统上运行时仔细检查列表内容
PowerShell自动化脚本
创建一个批量安装开发环境的PowerShell脚本setup-dev-env.ps1:
$packages = @(
"Microsoft.VisualStudioCode",
"Git.Git",
"OpenJS.NodeJS.LTS",
"Python.Python.3.11",
"Docker.DockerDesktop"
)
foreach ($package in $packages) {
winget install $package --silent --accept-package-agreements --accept-source-agreements
Write-Host "已安装: $package"
}
四、常见问题解决方案
网络连接错误处理
遇到0x80072efd错误时,尝试切换下载器:
winget settings
在配置文件中添加:
"network": {
"downloader": "wininet"
}
安装权限问题
当提示"需要管理员权限"时,可通过PowerShell的Start-Process命令以管理员身份运行:
Start-Process winget -ArgumentList "install Microsoft.PowerToys" -Verb RunAs
源同步失败修复
若winget source update失败,尝试重置默认源:
winget source reset --force
五、参与项目贡献与发展
项目未来发展方向
winget-cli正处于持续发展中,未来版本将重点提升以下功能:
- 增强依赖管理系统,支持复杂软件依赖关系
- 改进配置管理,提供更精细的策略控制
- 优化搜索算法,提供更相关的搜索结果
- 提升性能,加快软件包处理速度
社区贡献途径
作为开源项目,你可以通过多种方式参与贡献:
- 报告问题:在项目issue中提交bug报告和功能建议
- 代码贡献:提交PR修复bug或实现新功能
- 完善文档:改进使用文档和帮助信息
- 测试验证:参与测试新版本并提供反馈
项目代码仓库:https://gitcode.com/gh_mirrors/wi/winget-cli
💡 技巧:首次贡献者可从"good first issue"标签的任务入手,这些任务通常难度较低且有详细指导
通过本文介绍的方法,你已经掌握了使用winget-cli管理Windows软件的核心技能。无论是日常使用还是企业环境部署,winget都能显著提升软件管理效率。随着项目的不断发展,它将成为Windows平台不可或缺的软件管理工具。现在就开始尝试用命令行管理你的第一个软件吧!
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
jiuwenclawJiuwenClaw 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。Python0214- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
AtomGit城市坐标计划AtomGit 城市坐标计划开启!让开源有坐标,让城市有星火。致力于与城市合伙人共同构建并长期运营一个健康、活跃的本地开发者生态。01
OpenDeepWikiOpenDeepWiki 是 DeepWiki 项目的开源版本,旨在提供一个强大的知识管理和协作平台。该项目主要使用 C# 和 TypeScript 开发,支持模块化设计,易于扩展和定制。C#00


