首页
/ 如何用winget-cli管理Windows软件:从入门到自动化部署

如何用winget-cli管理Windows软件:从入门到自动化部署

2026-03-10 03:17:50作者:董灵辛Dennis

你是否还在为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

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升级功能演示

管理软件源配置

查看当前配置的软件源:

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导出功能演示

在新系统上恢复软件环境:

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正处于持续发展中,未来版本将重点提升以下功能:

  • 增强依赖管理系统,支持复杂软件依赖关系
  • 改进配置管理,提供更精细的策略控制
  • 优化搜索算法,提供更相关的搜索结果
  • 提升性能,加快软件包处理速度

社区贡献途径

作为开源项目,你可以通过多种方式参与贡献:

  1. 报告问题:在项目issue中提交bug报告和功能建议
  2. 代码贡献:提交PR修复bug或实现新功能
  3. 完善文档:改进使用文档和帮助信息
  4. 测试验证:参与测试新版本并提供反馈

项目代码仓库:https://gitcode.com/gh_mirrors/wi/winget-cli

💡 技巧:首次贡献者可从"good first issue"标签的任务入手,这些任务通常难度较低且有详细指导

通过本文介绍的方法,你已经掌握了使用winget-cli管理Windows软件的核心技能。无论是日常使用还是企业环境部署,winget都能显著提升软件管理效率。随着项目的不断发展,它将成为Windows平台不可或缺的软件管理工具。现在就开始尝试用命令行管理你的第一个软件吧!

登录后查看全文
热门项目推荐
相关项目推荐