每一个开发人员都应该知道的8个Linux命令

每一个开发人员到了他们职业人生的某个阶段的时候,将会发现本身要寻找有关Linux的信息。我并非这方面的专家。可是掌握了如下8个Linux命令,我几乎能够获得我任何须要的东西。html

注意:如下的命令都有不少扩展的文档,博客里提出的知识我最经常使用的命令,用法。若是你不了解Linux命令,这个帖子会给你一点指导。linux


咱们以一些文本举例。假设咱们有2个文件,里面有订单关于第三方的放置地点和发送回应。正则表达式

order.out.log
8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:23:45 112, 1, Joy of Clojure, Hardcover, 29.99
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99less

order.in.log
8:22:20 111, Order Complete
8:23:50 112, Order sent to fulfillment
8:24:20 113, Refund sent to processing编辑器


cat视频

–追加文件并在标准输出上打印htm

jfields$ cat order.out.log
8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:23:45 112, 1, Joy of Clojure, Hardcover, 29.99
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99blog


正如他的名字所说的,你能够串联多个文件排序

jfields$ cat order.*
8:22:20 111, Order Complete
8:23:50 112, Order sent to fulfillment
8:24:20 113, Refund sent to processing
8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:23:45 112, 1, Joy of Clojure, Hardcover, 29.99
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99教程

看到效果了,但咱们能够提升其可读性。


sort

–对文本文件进行行排序,这里使用排序是不错的选择

jfields$ cat order.* | sort
8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:22:20 111, Order Complete
8:23:45 112, 1, Joy of Clojure, Hardcover, 29.99
8:23:50 112, Order sent to fulfillment
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:24:20 113, Refund sent to processing

上面显示了咱们想要看到的效果,可是这只是小文件。而真实的数据是很大的,有些是你不想要的数据怎么办?


grep

grep, egrep, fgrep–进行匹配输出

假设我只关心给PofEAA的订单,使用grep就能够作到。

jfields$ cat order.* | sort | grep Patterns
8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99


假设订单113里面发生了一些问题,你想看到关于113的全部订单信息。没错,grep能帮你。

jfields$ cat order.* | sort | grep “:\d\d 113, ”
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:24:20 113, Refund sent to processing


你会发如今表达式里面不止有113,这是由于113也可能出如今价格里面,或者产品里面,这样作是严格限制其查找结果。

如今咱们已经发出退货订单的信息,咱们每日也要给会计发送销售统计。他们要求每一个PofEAA的项目,但他们只关心数量和价格,咱们要把不须要的部分删减掉。


cut

–从文件的每一行删除一部分

仍是要先使用grep。

jfields$ cat order.* | sort | grep Patterns
8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99
jfields$ cat order.* | sort | grep Patterns | cut -d”,” -f2,5
1, 39.99
-1, 39.99

咱们已经减小了数据,让会计一目了然。

假设会计想要把订单ID作为参考,把它放在每一行的最后,并用单引号。


sed

–流编辑器。用来处理文本转换。

下面的示例演示怎样使用它来作到咱们想要的数据。

jfields$ cat order.* | sort | grep Patterns \
>| sed s/”[0-9\:]* \([0-9]*\)\, \(.*\)”/”\2, ‘\1′”/
1, Patterns of Enterprise Architecture, Kindle edition, 39.99, ’111′
-1, Patterns of Enterprise Architecture, Kindle edition, 39.99, ’113′
lmp-jfields01:~ jfields$ cat order.* | sort | grep Patterns \
>| sed s/”[0-9\:]* \([0-9]*\)\, \(.*\)”/”\2, ‘\1′”/ | cut -d”,” -f1,4,5
1, 39.99, ’111′
-1, 39.99, ’113′

这是一个正则表达式,但没什么复杂的。


作如下事情

1.删除时间
2.捕获订单号
3.删除逗号和订单号后面的空格
4.捕获此行的其他部分

一旦咱们看到了咱们须要的数据,可使用\1&\2让输出数据符合咱们的格式要求。


uniq

–去除重复行

下面的示例演示如何grep的惟一相关的交易,削减没必要要的信息,并得到计数。

jfields$ cat order.out.log | grep “\(Kindle\|Hardcover\)” | cut -d”,” -f3 | sort | uniq -c
1 Joy of Clojure
2 Patterns of Enterprise Architecture

jfields$ cat order.out.log | grep “\(Kindle\|Hardcover\)” | cut -d”,” -f3 | sort | uniq
Joy of Clojure
Patterns of Enterprise Architecture


find

–在目录里找文件

假设这2个文本文件存在于咱们的主目录,咱们没必要知道他们的全名。

jfields$ find /Users -name “order*”
Users/jfields/order.in.log
Users/jfields/order.out.log

固然还有不少选项,但99%的状况下我这么作。


less

–在一个文件里面向前向后移动

让咱们回到最简单的cat|sort的例子。你能够向前搜索使用”/”,向后使用”?”,2者均可以使用正则表达式。

jfields$ cat order* | sort | less

你能够试试/113.*,这将突出显示订单113。你可使用?.*112,也将突出显示订单112,你能够用’q'退出。


Linux命令很丰富,有些人很头疼。这几个命令应该能帮你完成大部分的文本工做,不用交到你的脚本语言手里。

 

更多精彩linux视频教程,尽在51CTO学院:
wKioL1PE_n3z629yAACXIHScsJM092.jpg
相关文章
相关标签/搜索