在线客服
扫描二维码
下载博学谷APP
扫描二维码
关注博学谷微信公众号
众所周知,Bash历史记录里有许多快捷方式的记录,让人眼花缭乱。其实这些快捷方式使用起来,可以极大的提高我们学习和工作的效率。如果大家觉得这些方式很难记,可以循序渐进,每天只学一点内容,这样就能轻松掌握。下面小编将选五个最常用到的Bash历史记录操作方式为大家介绍。

1、最后一个参数:!$
如果你仅想从本文中学习一种快捷方式,那就是这个。它会将最后一个命令的最后一个参数替换到你的命令行中。
看看这种情况:
啊哈,我在命令中写了错误的文件名 “wrongfile”,我应该用正确的文件名 “rightfile” 代替。
你可以重新键入上一个命令,并用 “rightfile” 完全替换 “wrongfile”。但是,你也可以键入:
这个命令也可以奏效。
在 Bash 中还有其他方法可以通过快捷方式实现相同的目的,但是重用上一个命令的最后一个参数的这种技巧是我最常使用的。
2、搜索并替换:!!:gs
这将搜索所引用的命令,并将前两个/之间的字符替换为后两个/之间的字符。
假设我想告诉别人我的s键不起作用,而是输出了f:
然后我意识到这里出现的f键都是错的。要将所有f替换为s,我可以输入:
它不只对单个字符起作用。我也可以替换单词或句子:
测试一下
为了向你展示如何组合这些快捷方式,你知道这些命令片段将输出什么吗?
3、全部参数:!:1-$
假设我运行了类似这样的命令:
参数是正确的。然而,我想在文件中匹配 “ping” 或 “pong”,但我使用的是grep而不是egrep。
我开始输入egrep,但是我不想重新输入其他参数。因此,我可以使用!:1-$快捷方式来调取上一个命令的所有参数,从第二个(记住它们的索引从零开始,因此是1)到最后一个(由$表示)。
你不用必须用1-$选择全部参数;你也可以选择一个子集,例如1-2或3-9(如果上一个命令中有那么多参数的话)。
4、倒数第 n 行的最后一个参数:!-2:$
当我输错之后马上就知道该如何更正我的命令时,上面的快捷键非常有用,但是我经常在原来的命令之后运行别的命令,这意味着上一个命令不再是我所要引用的命令。
例如,还是用之前的mv例子,如果我通过ls检查文件夹的内容来纠正我的错误:
我就不能再使用!$快捷方式了。
在这些情况下,我可以在!之后插入-n:(其中n是要在历史记录中回溯的命令条数),以从较旧的命令取得最后的参数:
同样,一旦你学会了它,你可能会惊讶于你需要使用它的频率。
5、进入文件夹:!$:h
从表面上看,这个看起来不太有用,但我每天要用它几十次。
想象一下,我运行的命令如下所示:
我可能要做的第一件事是转到/etc文件夹,查看其中的内容并找出我做错了什么。
我可以通过以下方法来做到这一点:
这是说:“获取上一个命令的最后一个参数(/etc/system),并删除其最后的文件名部分,仅保留/etc。”
以上就是五个最常用的Bash历史记录操作方式,大家都记住了吗?没有记住也不要紧,大家可以收藏着慢慢学习。觉得本文对自己有所帮助的小伙伴,就分享一下让更多的人看见吧!
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
学数据库要看哪些书?从入门到精通书籍推荐
学数据库要看哪些书?本文就针对数据库这一知识点,给大家推荐七本书籍。这些书既有零基础可以看懂的,又有可以进阶提升的内容,内容上真正做到从入门到精通都涵概。
10792
2019-08-07 10:04:35
学C++应该看哪些书?零基础入门书籍推荐
近些年来,虽然各种编程语言层出不穷,但是C++的地位依然比较稳固,在某些领域具有不可替代的作用。那么学C++应该看哪些书?本文就是为零基础入门的小伙伴推荐十本书籍。
10013
2019-08-12 20:19:43
男生学IT程序员需要学历吗?
男生学IT程序员的学历要求,学历在一定层面上证明一个人的思维逻辑和理解能力,学习能力的体现,学历越高学习的效率会越高,学习IT技术越容易;如果很感兴趣,学历的门槛并不高,现在很多学校开展了少儿编程或零基础学编程,可见男生学IT技术学历并不是必须条件。
6676
2020-03-18 10:37:22
嵌入式是什么?嵌入式培训难吗?
嵌入式技术的兴起让许多小伙伴看中了它的发展前景,想要学习嵌入式,成为一名嵌入式工程师。但其实很多人只是因为她的广阔发展前景而想要去学它,但其实并不知道嵌入式到底是什么,还会担心嵌入式培训难吗?
6591
2020-06-09 14:27:55
如何通过建立索引优化SQL?
优化SQL是一个老生常谈的问题,我们可以从多方面入手对SQL进行优化。今天本文主要从应用层来看,如何通过建立索引优化SQL。索引的数据结构B+Tree有着较高的查询性能,因此建立索引主要是对SQL 的查询性能进行优化。下面我们一起来看看建立普通索引、建立复合索引、最左前缀匹配原则、索引下推、覆盖索引、普通索引等等内容吧~
6685
2020-06-24 17:37:23
