17个有用的CLI命令

作为前端开发工程师,我们需要了解哪些命令?如果您熟悉这些命令,它们将大大提高您的工作效率。

1. tree

你们知道如何列出一个目录的文件结构吗?它在显示文件之间的目录关系方面做得很好

复制代码
commands`
`├── a.js`
`├── b.js`
`├── c.js`
`├── copy-apps`
`│   └── fe-apps`
`│       └── a.js`
`├── fe-apps`
`│   └── a.js`
`├── test.log`
`└── xxx`
`    └── yyy`
`

在此之前,您需要安装命令树。

复制代码
brew install tree`
`

然后只需在文件目录中执行tree即可。

2. wc

wc 是 word count 的缩写,常用于文件统计。它可以统计字数、行数、字符数、字节数等。

我经常用它来计算文件中的代码行数。

3. du

打印出一个目录的文件大小信息。我们使用它的频率较低,但它是一个非常值得学习的命令。

  • du -h:打印出适合人类阅读的信息。
  • du -a:列出目录中文件大小的信息;
  • du -s:只显示总大小,不显示具体信息。
复制代码
➜  commands git:(master) ✗ du`
`0  ./xxx/yyy`
`0  ./xxx`
`0  ./fe-apps`
`0  ./copy-apps/fe-apps`
`0  ./copy-apps`
`0  ./.git/objects/pack`
`0  ./.git/objects/info`
`0  ./.git/objects`
`8  ./.git/info`
`104  ./.git/hooks`
`0  ./.git/refs/heads`
`0  ./.git/refs/tags`
`0  ./.git/refs`
`136  ./.git`
`168  .`
`
复制代码
➜  commands git:(master) ✗ du -h`
`  0B  ./xxx/yyy`
`  0B  ./xxx`
`  0B  ./fe-apps`
`  0B  ./copy-apps/fe-apps`
`  0B  ./copy-apps`
`  0B  ./.git/objects/pack`
`  0B  ./.git/objects/info`
`  0B  ./.git/objects`
`4.0K  ./.git/info`
` 52K  ./.git/hooks`
`  0B  ./.git/refs/heads`
`  0B  ./.git/refs/tags`
`  0B  ./.git/refs`
` 68K  ./.git`
` 84K  .`
`
复制代码
➜  commands git:(master) ✗ du -ha`
`4.0K  ./a.js`
`  0B  ./xxx/yyy`
`  0B  ./xxx`
`  0B  ./fe-apps/a.js`
`  0B  ./fe-apps`
`4.0K  ./test.log`
`  0B  ./copy-apps/fe-apps/a.js`
`  0B  ./copy-apps/fe-apps`
`  0B  ./copy-apps`
`4.0K  ./c.js`
`4.0K  ./.git/config`
`  0B  ./.git/objects/pack`
`  0B  ./.git/objects/info`
`  0B  ./.git/objects`
`4.0K  ./.git/HEAD`
`4.0K  ./.git/info/exclude`
`4.0K  ./.git/info`
`4.0K  ./.git/description`
`4.0K  ./.git/hooks/commit-msg.sample`
`8.0K  ./.git/hooks/pre-rebase.sample`
`4.0K  ./.git/hooks/pre-commit.sample`
`4.0K  ./.git/hooks/applypatch-msg.sample`
`4.0K  ./.git/hooks/fsmonitor-watchman.sample`
`4.0K  ./.git/hooks/pre-receive.sample`
`4.0K  ./.git/hooks/prepare-commit-msg.sample`
`4.0K  ./.git/hooks/post-update.sample`
`4.0K  ./.git/hooks/pre-merge-commit.sample`
`4.0K  ./.git/hooks/pre-applypatch.sample`
`4.0K  ./.git/hooks/pre-push.sample`
`4.0K  ./.git/hooks/update.sample`
` 52K  ./.git/hooks`
`  0B  ./.git/refs/heads`
`  0B  ./.git/refs/tags`
`  0B  ./.git/refs`
` 68K  ./.git`
`4.0K  ./b.js`
` 84K  .`
`
复制代码
du -sh`
`

4. alias

alias命令用于设置命令的别名。如果您仅键入别名,将列出所有当前别名设置。

让我们尝试为 git status 设置一个别名

复制代码
alias gs="git status"`
`

值得注意的是:如果你想让gs命令永久存在,你应该在.profile或.zshrc中设置它。

5. grep

我们经常需要查找服务器上日志文件的内容,grep将是我们得心应手的帮手。

有一个日志文件test.log。它包含以下内容:

复制代码
const a = 1`
`const b = 2`
`const c = 3`
`
复制代码
console.log(a + b + c)`
`

如何突出显示包含 a 字符的位置?这很容易,不是吗?

复制代码
grep a test.log`
`

6. cat

cat 的主要用途是查看文件的内容并将其打印在屏幕上。

但它至少还有一些其他用途。

1.清除a.js的内容

复制代码
➜  commands git:(master) ✗ cat a.js // There are two lines of code in a.js`
`const a = 'fatfish'`
`
复制代码
console.log(a)%`
`➜  commands git:(master) ✗ cat /dev/null > a.js // clear the contents of a.js`
`➜  commands git:(master) ✗ cat a.js // The content in a.js is cleared.`
`➜  commands git:(master) ✗`
`

2.将a.js的内容复制到b.js

复制代码
➜  commands git:(master) ✗ cat a.js`
`const name = 'fatfish'`
`console.log(name)`
`➜  commands git:(master) ✗ cat b.js // No content in b.js`
`➜  commands git:(master) ✗ cat a.js > b.js // Copy the contents of a.js to b.js`
`➜  commands git:(master) ✗ cat b.js // The content in b.js is the same as in a.js`
`const name = 'fatfish'`
`console.log(name)`
`➜  commands git:(master) ✗ cat a.js`
`const name = 'fatfish'`
`console.log(name)`
`

3.将a.js的内容添加到c.js的最后一个字符

复制代码
➜  commands git:(master) ✗ cat a.js`
`const name = 'fatfish'`
`console.log(name)%`
`➜  commands git:(master) ✗ cat c.js`
`const age = 100`
`console.log(age)`
`➜  commands git:(master) ✗ cat a.js >> c.js`
`➜  commands git:(master) ✗ cat c.js`
`const age = 100`
`console.log(age)const name = 'fatfish'`
`console.log(name)`
`

7. clear

有时候,我们需要在终端中进行一些操作,这样屏幕上的内容就足以让我们感到烦恼了。

如何清除它们?我们需要逐行删除它们吗?

8. cp

cp命令用于复制文件或目录。

cp -f:当要复制的文件覆盖已有的目标文件时,不会有提示信息。

cp -r:如果复制的文件是目录文件,则复制该目录下的所有子目录和文件。

复制代码
➜  commands git:(master) ✗ ls -R`
`a.js      b.js      copy-apps fe-apps`
`./copy-apps:`
`./fe-apps:`
`// 1. copy a file`
`➜  commands git:(master) ✗ cp a.js fe-apps`
`➜  commands git:(master) ✗ ls -R`
`a.js      b.js      copy-apps fe-apps`
`./copy-apps:`
`./fe-apps:`
`a.js`
`➜  commands git:(master) ✗ cp fe-apps copy-apps`
`cp: fe-apps is a directory (not copied).`
`// 2. copy a directory`
`➜  commands git:(master) ✗ cp -rf fe-apps copy-apps`
`➜  commands git:(master) ✗ ls -R`
`a.js      b.js      copy-apps fe-apps`
`./copy-apps:`
`fe-apps`
`./copy-apps/fe-apps:`
`a.js`
`./fe-apps:`
`a.js`
`

9. cd

这篇文章肯定没什么技术性,因为关于 cd 真的没什么可写的,作为一个开发者,谁不熟悉它呢?

也许你是对的,但我只是想说 cd - 可以返回到你上次访问的目录。我认为这是一个好技巧。

10. ls

这是一个非常常用的命令,它用于显示文件目录的内容列表。

它至少可以通过 3 种方式使用。

  • ls -a:显示所有文件和目录(包括以.目录开头的)
  • ls -A:显示所有文件和目录(不包括以.directory开头的目录)
  • ls -R:显示所有文件和目录,如果目录中有文件,则按顺序列出

11. rm

它用于删除文件或目录。

rm -i:将目录下的文件逐个删除,删除前会询问是否删除该文件。

rm -r:一起处理指定目录及其子目录下的所有文件(注:不删除文件。)

rm -f:用于强制删除文件或目录。

12. tail

我想你一定也有在服务器上查看日志内容的经历,tail绝对是一个好帮手。

tail -f filename 会将 filename 尾部的内容显示在屏幕上,当其内容发生变化时,您将在屏幕上看到最新的内容。

13. mv

有时我们想要更改一个文件或目录的名称,或者将其移动到另一个地方,那么我们可以使用 mv 命令。

1.修改文件名

复制代码
➜  commands git:(master) ✗ ls`
`a.js`
`➜  commands git:(master) ✗ mv a.js xxx.js`
`➜  commands git:(master) ✗ ls`
`xxx.js`
`➜  commands git:(master) ✗`
`

2. 将文件移动到其他目录

复制代码
➜  commands git:(master) ✗ ls -R`
`a.js    fe-apps`
`./fe-apps:`
`xxx.js`
`➜  commands git:(master) ✗ mv a.js fe-apps`
`➜  commands git:(master) ✗ ls -R`
`fe-apps`
`./fe-apps:`
`a.js   xxx.js`
`

14.touch

我经常使用 touch 命令来创建新文件,尽管它是用来修改文件或目录的时间属性的。

15.which

如果你想查看某个命令的具体路径,可以使用which。

复制代码
➜  commands git:(master) ✗ which node`
`/Users/dz0400229/.nvm/versions/node/v16.0.0/bin/node`
`➜  commands git:(master) ✗ which npm`
`/Users/dz0400229/.nvm/versions/node/v16.0.0/bin/npm`
`➜  commands git:(master) ✗ which npx`
`/Users/dz0400229/.nvm/versions/node/v16.0.0/bin/npx`
`➜  commands git:(master) ✗`
`

16.mkdir

是的,您以前肯定使用过这个命令,而且没什么可说的!

但是mkdir -p dirname确实是我们很少使用的东西,它是用来做什么的呢?

复制代码
➜  commands git:(master) ✗ ls`
`a.js      b.js      copy-apps fe-apps`
`➜  commands git:(master) ✗ mkdir xxx/yyy // You cannot create the yyy directory because the xxx directory does not exist`
`mkdir: xxx: No such file or directory`
`➜  commands git:(master) ✗ mkdir -p xxx/yyy // `-p` will check if the xxx directory already exists, and create it if it doesn't.`
`➜  commands git:(master) ✗ ls`
`a.js      b.js      copy-apps fe-apps   xxx`
`➜  commands git:(master) ✗ ls -R`
`a.js      b.js      copy-apps fe-apps   xxx`
`./copy-apps:`
`fe-apps`
`./copy-apps/fe-apps:`
`a.js`
`./fe-apps:`
`a.js`
`./xxx:`
`yyy`
`./xxx/yyy:`
`

17.whoami

显示用户名。

复制代码
➜  commands git:(master) ✗ whoami`
`dz0400229`
`

关于优联前端

武汉优联前端科技有限公司由一批从事前端10余年的专业人才创办,是一家致力于H5前端技术研究的科技创新型公司,为合作伙伴提供专业高效的前端解决方案,合作伙伴遍布中国及东南亚地区,行业涵盖广告,教育, 医疗,餐饮等。有效的解决了合作伙伴的前端技术难题,节约了成本,实现合作共赢。

相关推荐
超级阿飞1 小时前
利用Kubespray安装生产环境的k8s集群-实施篇
elasticsearch·容器·kubernetes
Ase5gqe6 小时前
大数据-259 离线数仓 - Griffin架构 修改配置 pom.xml sparkProperties 编译启动
xml·大数据·架构
史嘉庆6 小时前
Pandas 数据分析(二)【股票数据】
大数据·数据分析·pandas
唯余木叶下弦声7 小时前
PySpark之金融数据分析(Spark RDD、SQL练习题)
大数据·python·sql·数据分析·spark·pyspark
重生之Java再爱我一次8 小时前
Hadoop集群搭建
大数据·hadoop·分布式
GISer_Jing9 小时前
React+AntDesign实现类似Chatgpt交互界面
前端·javascript·react.js·前端框架
豪越大豪10 小时前
2024年智慧消防一体化安全管控年度回顾与2025年预测
大数据·科技·运维开发
互联网资讯10 小时前
详解共享WiFi小程序怎么弄!
大数据·运维·网络·人工智能·小程序·生活
小诺大人11 小时前
Docker 安装 elk(elasticsearch、logstash、kibana)、ES安装ik分词器
elk·elasticsearch·docker
AI2AGI12 小时前
天天AI-20250121:全面解读 AI 实践课程:动手学大模型(含PDF课件)
大数据·人工智能·百度·ai·文心一言