Linux shell命令帮助格式详解

发布时间 - 2026-01-10 22:46:04    点击率:

前言

linux shell命令通常可以通过-h--help来打印帮助说明,或者通过man命令来查看帮助,有时候我们也会给自己的程序写简单的帮助说明,其实帮助说明格式是有规律可循的

帮助示例

下面是git reset命令的帮助说明,通过man git-reset可以查看

git reset [-q] [<tree-ish>] [--] <paths>...
git reset (--patch | -p) [<tree-ish>] [--] [<paths>...]
git reset [--soft | --mixed | --hard | --merge | --keep] [-q] [<commit>]

对于命令和参数大致有如下几种类型

  • 没有任何修饰符参数 : 原生参数
  • <>  : 占位参数
  • []  : 可选组合
  • ()  : 必选组合
  • |   : 互斥参数
  • ... : 可重复指定前一个参数
  • --  : 标记后续参数类型

下面来一一介绍

参数类型解读

原生参数

说明文档里的字符即为命令需要使用的字符,比如以上命令的

git reset

这种参数在使用时必需指定,且和说明文档里的一致

占位参数

表示方式: <>

和原生参数类似,都是必需指定的,只不过占位参数的实际字符是在使用时指定的,同时为了方便阅读会用一个描述词汇来表示,并以<>包围,比如

<paths>

表示路径,使用时可以指定为具体的路径,而paths只是起一个说明作用,有些帮助说明里也会用大写来表示占位参数,比如将以上参数说明写成PATHS

可选组合

表示方式:  []

括号里的参数为可选参数,比如usage第二个里面的[-q] ,则-q为可选参数

可选项和占位参数也可以同时使用,如

[<commit>]

表示该参数可以指定某次提交,也可以不指定

必选组合

表示方式:  ()

括号里的参数必需指定,通常里面会是一些互斥参数,比如

(--patch | -p)

表示--patch-p这两个参数必需指定一个

互斥参数

表示方式:  |

互斥参数一般都在()[]里,表示该参数只能指定其中一个,比如

[--mixed | --soft | --hard | --merge | --keep]

重复参数

表示方式: ...

表示前一个参数可以被指定多个,比如

<paths>...

<paths>是一个占位参数,使用时必需指定为路径,...并表示可以指定多个路径。重复参数的一个典型使用场景就是移动文件,将多个文件移动到一个目录下,比如如下命令

git mv [<options>] <source>... <destination>

我们可以这样使用

git mv -f a.cpp b.py dir

此时options对应为-f参数,source对应为a.cpp b.py,destination对应为dir

标记后续参数类型

表示方式: --

表示后续参数的某种类型,比如这里如果使用如下命令

git reset -p -- xx

对比第一个命令,这里的xx对应的应该是<paths>参数,当我们指定--之后,则git会认为xx就是一个路径,那怕它是特殊符号或者路径并不存在。这是shell命令的一个通用方式,比如我们有一个文件名为-h,如果想删除这个文件,执行

rm -h

肯定是无法删除的,因为这时-h会被认为是rm的一个参数选项,应该使用

rm -- -h

这时shell会将-h解释为一个文件名传递给rm命令

解读实战

最后来解释一个比较复杂的帮助说明

git cat-file (-t [--allow-unknown-type]|-s [--allow-unknown-type]|-e|-p|<type>|--textconv) <object>

该命令参数由四个部分,其中gitcat-file为原生参数,()里的为可选组合, <object>为占位参数

组合又由6部分组成,为互斥关系

-t [--allow-unknown-type]
-s [--allow-unknown-type]
-e
-p
<type>
--textconv

因此该命令的帮助说明可以拆分如下

git cat-file -t <object>
git cat-file -t --allow-unknown-type <object>
git cat-file -s <object>
git cat-file -s --allow-unknown-type <object>
git cat-file -e <object>
git cat-file -p <object>
git cat-file <type> <object>
git cat-file --textconv <object>

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。


# linux  # 命令帮助  # 格式  # shell命令  # linux查看命令帮助  # linux touch  # chattr指令详解及用法  # php在linux中可能用到的命令(推荐)  # 详解Linux命令修改文件的三个时间  # Linux C字符串替换函数实例详解  # linux 详解useradd 命令基本用法  # Linux shell tr 命令详解  # 浅谈Linux 脚本 sh 和 ./ 的区别  # Linux监视进程之ps命令详解  # linux指令man page之rm  # mv详解  # 可选  # 多个  # 互斥  # 会用  # 都是  # 是一个  # 这是  # 文档  # 是在  # 括号里  # 也会  # 都在  # 第一个  # 是有  # 没有任何  # 它是  # 我们可以  # 这两个  # 可以通过  # 给自己 


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


相关推荐: laravel怎么通过契约(Contracts)编程_laravel契约(Contracts)编程方法  消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工  简单实现Android验证码  如何在Windows 2008云服务器安全搭建网站?  Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】  如何用西部建站助手快速创建专业网站?  EditPlus中的正则表达式实战(5)  Windows驱动无法加载错误解决方法_驱动签名验证失败处理步骤  EditPlus 正则表达式 实战(3)  如何在香港服务器上快速搭建免备案网站?  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  制作旅游网站html,怎样注册旅游网站?  如何在IIS中新建站点并配置端口与物理路径?  Android实现代码画虚线边框背景效果  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  个人网站制作流程图片大全,个人网站如何注销?  电商网站制作价格怎么算,网上拍卖流程以及规则?  Python文本处理实践_日志清洗解析【指导】  文字头像制作网站推荐软件,醒图能自动配文字吗?  laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法  如何在企业微信快速生成手机电脑官网?  企业网站制作这些问题要关注  javascript基于原型链的继承及call和apply函数用法分析  如何快速生成凡客建站的专业级图册?  Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】  Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程  如何在万网利用已有域名快速建站?  微信推文制作网站有哪些,怎么做微信推文,急?  如何做网站制作流程,*游戏网站怎么搭建?  Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】  Python函数文档自动校验_规范解析【教程】  laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  Python企业级消息系统教程_KafkaRabbitMQ高并发应用  Laravel怎么为数据库表字段添加索引以优化查询  香港服务器部署网站为何提示未备案?  使用豆包 AI 辅助进行简单网页 HTML 结构设计  html5audio标签播放结束怎么触发事件_onended回调方法【教程】  Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  lovemo网页版地址 lovemo官网手机登录  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  浅谈javascript alert和confirm的美化  微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  详解Android——蓝牙技术 带你实现终端间数据传输  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】