游乐游手机版
首页/编程语言/文章详情

Composer怎么查看已安装的所有包_Composer如何用show列出项目的依赖列表【命令】

时间:2026-05-03 15:17
Composer怎么查看已安装的所有包_Composer如何用show列出项目的依赖列表【命令】 composer show 不加参数就能列出全部已安装包 其实,想快速摸清项目依赖的家底,最直接的办法就是运行 composer show。这个命令会立刻输出当前项目 vendor 目录下所有已安装的

Composer怎么查看已安装的所有包_Composer如何用show列出项目的依赖列表【命令】

Composer怎么查看已安装的所有包_Composer如何用show列出项目的依赖列表【命令】

composer show 不加参数就能列出全部已安装包

其实,想快速摸清项目依赖的家底,最直接的办法就是运行 composer show。这个命令会立刻输出当前项目 vendor/ 目录下所有已安装的包,清清楚楚地列出包名、版本号和简短描述。它读取的数据源是 vendor/composer/installed.json(或者 installed.php),这比直接看 composer.lock 更贴近运行时实际加载的状态。

这里有个常见的理解偏差:很多人以为必须加上 -a--all 参数才能看到全部。其实恰恰相反,不加任何参数就是默认展示全量列表;而 --all 参数的作用,主要是为了把平台包(比如 ext-curlphp 本身)也一并包含进来。

  • 如果只想快速浏览包名和版本,可以用 composer show --name-only(要求 Composer 2.5+ 版本),或者在 Linux/macOS 下用管道处理:composer show | cut -d' ' -f1
  • 打算把列表导出为纯文本,方便后续用 grep 等工具处理?加上 --format=txt 参数会更稳妥(虽然它和默认格式基本等价)。
  • 需要警惕的是:如果项目从未执行过 composer installcomposer update,导致 vendor/ 目录是空的,那么运行 composer show 会直接报错 Could not find package

composer show vendor/name 查看单个包的详细信息

当你需要深入了解某个特定包时,比如想查看 monolog/monolog 的依赖树、源码仓库地址、自动加载配置或者所有可用版本,命令就变成了 composer show monolog/monolog。它会展示该包在本地实际安装的版本,并给出其 composer.json 元数据的一个快照。

值得注意的是,这个命令完全在本地运行,不联网,也不会查询 Packagist。它只读取已经安装在 vendor/ 里的包的元信息。所以,如果你刚刚用 composer require 添加了一个包,但还没执行 install,那么它是不会出现在查询结果里的。

  • 想看看某个包能升级到哪些版本?加上 --all 参数试试,例如 composer show monolog/monolog --all
  • 要判断一个包是项目直接依赖,还是被其他包间接引入的?可以查看输出中的 type 字段是否为 library,再结合项目根目录的 composer.json 文件里的 require 部分进行比对。
  • 如果遇到 Package not found 的提示,先别急。用 ls vendor/ 确认一下包目录是否存在,再仔细检查包名的大小写——Composer 的包名是严格区分大小写的,guzzlehttp/guzzleGuzzleHttp/Guzzle 会被视为两个不同的包。

composer show --tree 输出依赖关系树

想要理清“谁依赖了谁”这团乱麻?composer show --tree 是最直观的工具。它会从根项目开始,像展开一棵树一样,递归地展示每一层依赖关系,用缩进来清晰表示层级。这样一来,哪几个包共同引入了同一个子依赖(比如都依赖 psr/log)就一目了然了。

不过,它也有局限性:不会显示版本冲突或者未满足的版本约束。这类问题得靠 composer why-notcomposer prohibits 命令来诊断。另外,--tree 默认只展示运行时依赖(即 require 部分),不包括开发依赖(require-dev),除非你显式加上 --dev 参数。

  • 只想看开发依赖的树状结构?用 composer show --tree --dev
  • 想从庞大的依赖树中过滤出特定类型的包,比如所有 symfony/* 系列的?可以配合管道和 grep 命令:composer show --tree | grep "symfony/"
  • 这里有个容易踩坑的细节:如果某个包被项目中的多条依赖路径同时引入,--tree 命令默认只展示第一条路径,不会标记出重复引用的情况。所以,别用它来准确判断依赖的收敛效果。

composer show 和 composer depends 的关键区别

这是很多开发者容易混淆的地方。简单来说,composer show package/name 回答的是“这个包自己长什么样”,而 composer depends package/name 回答的是“谁在用它”。后者才是当你考虑是否要移除某个包时,用来判断“会不会影响其他组件”的关键命令。

举个例子,你想确认 doctrine/annotations 这个包是不是只有 doctrine/orm 在用,还是你自己的业务代码也直接 use 了它。这时候就该用 composer depends doctrine/annotations。它会列出所有直接依赖它的包,包括根项目本身(会显示为 root)。

  • 加上 --recursive 参数,可以看到间接依赖它的包(也就是“依赖的依赖”),但输出可能会非常冗长,使用时要谨慎。
  • depends 命令只列出包名,不显示具体的版本号。要查版本,还得回头用 show 命令或者去翻 composer.lock 文件。
  • 一个常被忽略的细节:depends 默认不会包含 require-dev 中的依赖,除非你显式加上 --dev 参数。否则,你可能会漏掉测试工具链里的调用关系。

话说回来,真正关键的不是死记硬背这几个命令,而是理解它们背后的逻辑:show 系列命令始终基于 vendor/ 目录下的已安装状态;而 dependsprohibits 这类命令,依赖的则是 composer.json 文件中声明的依赖关系逻辑。当这两者给出的信息不一致时,往往意味着 composer.lock 文件已经过期,或者有人手动改动过 vendor/ 目录里的内容了。

来源:https://www.php.cn/faq/2329758.html
上一篇Composer提示无效OAuth令牌_清理过期授权凭证【配置修复】 下一篇VSCode代码大纲视图_左下角Outline功能的使用指南
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

补充同频道和同主题内容,方便继续浏览更多相关内容。

同类最新

继续查看同栏目最近更新的文章。

更多
PyTorch中使用多维索引张量对高维张量批量索引的正确方法
编程语言 · 2026-07-03

PyTorch中使用多维索引张量对高维张量批量索引的正确方法

本文深入讲解如何在 PyTorch 中利用形状为 [b, k] 的索引张量 B,对形状为 [b, m, n] 的高维张量 A 执行高效批量索引,最终得到 [b, k, n] 的输出。核心思路在于合理扩展索引维度并配合 torch gather 实现精准的逐行抽取。 很多人处理高维张量的批量索引时都会

Go中...操作符解包切片传递可变参数函数
编程语言 · 2026-07-03

Go中...操作符解包切片传递可变参数函数

在 Go 语言中,` ` 运算符放在切片变量后面(如 `slice `)的作用是将该切片“展开”为多个独立参数,专门用于调用那些接受可变参数(` T`)的函数,例如 `append` 或 `fmt Println`。这是一种类型安全的语法糖,并非省略号或通配符,能够帮助开发者更简洁地处理

macOS与WSL2下PHP多版本切换失效问题排查与修复指南
编程语言 · 2026-07-03

macOS与WSL2下PHP多版本切换失效问题排查与修复指南

本文深入分析在 macOS 或 WSL2(Ubuntu)开发环境中,通过 Homebrew 管理 PHP 多版本时,php -v 始终显示旧版本(如 php@5 6)的深层原因,并给出系统性解决方案,覆盖 PATH 冲突、符号链接逻辑、Shell 初始化配置、系统残留配置等关键环节。 遇到这种情况的

PHP JSON解析深层嵌套对象属性访问失败的解决方法
编程语言 · 2026-07-03

PHP JSON解析深层嵌套对象属性访问失败的解决方法

使用 json_decode() 解析 API 返回的 JSON 数据时,经常遇到某个子属性无法正常获取,始终返回 NULL —— 这是许多 PHP 开发者都曾碰到过的棘手问题。通常并非数据丢失,而是对象嵌套层级比预期更深,导致访问路径不正确。 举例来说,你看到返回的 JSON 里有一个 appea

nnU-Net v2预处理卡死问题的成因分析与实用解决指南
编程语言 · 2026-07-03

nnU-Net v2预处理卡死问题的成因分析与实用解决指南

> 使用 nnUNetv2_plan_and_preprocess 处理大规模数据集(例如 704 例样本)时,程序常因多进程加载导致死锁而停滞。核心原因在于默认并发数过高引发资源竞争或 I O 阻塞,适当降低并发数即可稳定完成全量预处理。 你在使用 `nnunetv2_plan_and_prepr