composer如何统计项目中包的代码量_composer相关插件使用方法【详解】

发布时间 - 2026-01-19 00:00:00    点击率:
不能。composer show仅列出已安装包的名称、版本和描述,读取vendor/composer/installed.json,不含源码路径或行数信息;统计代码行数需用cloc等工具遍历文件系统。

composer show 能不能直接统计代码行数

不能。composer show 只列出已安装包的名称、版本和描述,不提供文件或行数信息。它读的是 vendor/composer/installed.json,里面没有源码路径或尺寸字段。

想统计代码量,必须落到文件系统层面:遍历 vendor/ 下每个包的源码目录,再用工具统计有效行数(排除空行、注释等)。

用 cloc 统计 vendor 包的代码行数(推荐方案)

cloc 是最靠谱的命令行代码统计工具,支持按目录、语言、排除规则精细控制。它能自动识别 PHP、JS、CSS 等,并跳过 tests/examples/vendor/(递归时防误入)等常见非生产代码路径。

在项目根目录执行:

cloc --exclude-dir=tests,Examples,docs,benchmarks,node_modules,.github,vendor/composer vendor/ --by-file --quiet

说明:

  • --exclude-dir 必须显式排除测试、文档等干扰目录,否则 vendor/ 里大量 demo 和 test 会严重虚高结果
  • vendor/composer 要单独排除——它是 Composer 自身元数据,不是包代码
  • --by-file 可定位到具体哪个包贡献最多,便于后续分析
  • --quiet 减少冗余输出,适合脚本集成

注意:cloc 不区分“你主动 require 的包”和“它们的依赖”,统计的是整个 vendor/ 目录结构下的实际文件。如需只算顶层依赖,得先用 composer show --tree 提取一级包路径,再逐个 cloc

用 composer-unused 检查未使用的包(间接降低代码量)

真正影响维护成本的不是总行数,而是「被加载但没调用」的包。这类包白占磁盘、拖慢 autoloader、增加安全扫描范围。

composer-unused 插件可静态分析 use 语句和函数调用,标出疑似未使用的包:

composer global require composer-unused/composer-unused
composer unused

常见误报点:

  • 运行时动态加载(class_exists($name)new $class)不会被检测到
  • PHP 扩展类(如 PDORedis)会被错误标记为未使用
  • 配置驱动的依赖(如 Laravel 的 Service Provider)需手动白名单

执行后它会输出类似这样的提示:
Package "symfony/polyfill-mbstring" is not used.
别急着删——先确认你的代码是否隐式依赖了它提供的函数别名(比如 mb_strlen() 在无扩展时由它兜底)。

自定义脚本统计“顶层 require 包”的代码量

如果只想知道 composer.jsonrequire 字段声明的那些包(不含 transitive deps)占多少行,得组合两个命令:

composer show --format=json | php -r "
\$j = json_decode(file_get_contents('php://stdin'), true);
foreach (\$j as \$pkg => \$info) {
    if (isset(\$info['type']) && \$info['type'] === 'library') {
        \$dir = 'vendor/' . \$pkg;
        if (is_dir(\$dir)) {
            echo \"\$pkg\\n\";
            passthru(\"cloc --quiet --exclude-dir=tests,Examples,docs \$dir 2>/dev/null | tail -n1 | awk '{print \$5}'\");
       

} } }"

这个脚本做了三件事:

  • composer show --format=json 获取所有已安装包的元数据
  • 过滤出 type: library 的包(排除 projectmetapackage 等)
  • 对每个包目录跑一次 cloc,只取最终的 code 行数列(第 5 列)

关键限制:cloc 默认不递归子目录的子目录,所以它只统计该包自身源码,不包含其 vendor/(如果有),这点比全量 vendor/ 统计更贴近“你引入的成本”。

真正难的不是跑出数字,而是判断哪一行该算、哪一行该忽略——比如一个包带了 5000 行测试代码,但你只用了它 3 个函数,这时候行数本身已经失去参考价值。盯住 composer-unused 的报告,比盯着总行数有用得多。


# php  # css  # laravel  # redis  # js  # git  # json  # node  # composer  # github  # 工具  # ai  # symfony  # format  # require  # pdo  # 递归  # class 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法  Windows驱动无法加载错误解决方法_驱动签名验证失败处理步骤  高防服务器如何保障网站安全无虞?  Laravel怎么实现模型属性的自动加密  教你用AI将一段旋律扩展成一首完整的曲子  DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  java ZXing生成二维码及条码实例分享  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  Laravel如何自定义错误页面(404, 500)?(代码示例)  php 三元运算符实例详细介绍  Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解  Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境  Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】  html文件怎么打开证书错误_https协议的html打开提示不安全【指南】  如何做网站制作流程,*游戏网站怎么搭建?  怎么用AI帮你为初创公司进行市场定位分析?  如何用y主机助手快速搭建网站?  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  EditPlus中的正则表达式 实战(2)  如何在阿里云香港服务器快速搭建网站?  如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环  用v-html解决Vue.js渲染中html标签不被解析的问题  Laravel如何使用Sanctum进行API认证?(SPA实战)  Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控  Python并发异常传播_错误处理解析【教程】  如何实现建站之星域名转发设置?  Laravel如何实现密码重置功能_Laravel密码找回与重置流程  Laravel怎么调用外部API_Laravel Http Client客户端使用  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  Laravel PHP版本要求一览_Laravel各版本环境要求对照  香港服务器部署网站为何提示未备案?  Laravel如何使用Telescope进行调试?(安装和使用教程)  Android Socket接口实现即时通讯实例代码  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  如何批量查询域名的建站时间记录?  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  高防服务器租用如何选择配置与防御等级?  Laravel如何与Pusher实现实时通信?(WebSocket示例)  Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】  Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】  如何快速辨别茅台真假?关键步骤解析  动图在线制作网站有哪些,滑动动图图集怎么做?  香港服务器建站指南:免备案优势与SEO优化技巧全解析  Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】  Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道  Laravel怎么使用artisan命令缓存配置和视图  javascript中的数组方法有哪些_如何利用数组方法简化数据处理  Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件  Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出