当前位置:金沙js333娱乐场 > 网络频道 > 金沙js333娱乐场:每个开发人员都应该知道的8个

金沙js333娱乐场:每个开发人员都应该知道的8个

文章作者:网络频道 上传时间:2019-10-19

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

下面的例子展示了如何用sed命令变换我们的文件行,之后我们在再用cut移除无用的信息。

find

find– 在文件目录中搜索文件

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

现在我们已经知道了退货的详细信息,我们还想知道日销售和退款总额。但我们只关心《Patterns of Enterprise Architecture》这本书的信息,而且只关心数量和价格。我现在要做到是切除我们不关心的任何信息。

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

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

jfields$ cat order.* | sort | grep Patterns | cut -d"," -f2,5

uniq

sed– 一个流编辑器。它是用来在输入流上执行基本的文本变换。

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

cut是用来消减信息、简化任务的,但对于输出内容,我们通常会有更复杂的形式。假设我们还需要知道订单的ID,这样可以用来关联相关的其他信息。我们用cut可以获得ID信息,但我们希望把ID放到行的最后,用单引号包上。

less

就像上面例子显示的,文件里的数据已经经过排序。对于一些小文件,你可以读取整个文件来处理它们,然而,真正的log文件通常有大量的内容,你不能不考虑这个情况。此时你应该考虑过滤出某些内容,把cat、sort后的内容通过管道传递给过滤工具。

cat

>| sed s/"[0-9:] ([0-9]*), (.*)"/"2, '1'"/*

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

cut– 删除文件中字符行上的某些区域

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

一旦捕捉到了我们想要的数据,我们可以使用 1 & 2 来存储它们,并把它们输出成我们想要的格式。我们还在其中加入了要求的单引号,为了保持格式统一,我们还加入了逗号。最后,用cut命令把不必要的数据删除。

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

jfields$ cat order.out.log | grep "(Kindle|Hardcover)" | cut -d"," -f3 | sort | uniq -c

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

假设我们只对Patterns of Enterprise Architecture这本书的订单感兴趣。使用grep,我们能限制只输出含有Patterns字符的订单。

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

【嵌牛导读】:Linux里有很丰富的各种命令,有些是很难用的。然而,学会了前面说的这8个命令,你已经能处理大量的log分析任务了,完全不需要用脚本语言写程序来处理它们。

看到效果了,但我们可以提高其可读性。

转载自: blog.csdn.net/linhx/article/details/7983185   有删节。

sed

8:24:20 113, Refund sent to processing

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

uniq

grep

jfields$ cat order.*

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.99

看起来这是一个很简单的任务。

这是一个正则表达式,但没什么复杂的。做以下事情

>| sed s/"[0-9:] ([0-9]*), (.*)"/"2, '1'"/ | cut -d"," -f1,4,5*

你会发现在表达式里面不止有113,这是因为113也可能出现在价格里面,或者产品里面,这样做是严格限制其查找结果。

8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99

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

cat 命令非常的简单,你从下面的例子可以看到。

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

Users/jfields/order.out.log

假设我只关心给PofEAA的订单,使用grep就可以做到。

8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99

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

删除时间戳

现在我们已经发出退货订单的信息,我们每日也要给会计发送销售统计。他们要求每个PofEAA的项目,但他们只关心数量和价格,我们要把不需要的部分删减掉。 【Linux公社 http://www.linuxidc.com

下面的例子展示了如何过滤出跟书相关的交易,删除不需要的信息,获得一个不重复的信息。

–去除重复行

1, Patterns of Enterprise Architecture, Kindle edition, 39.99, '111'

cut

less

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

8:22:20 111, Order Complete

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.99

8:24:20 113, Refund sent to processing

金沙js333娱乐场 1

cat

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

8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99

我们已经减少了数据,让会计一目了然。

【嵌牛提问】:分别是哪些命令呢?

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

8:24:20 113, Refund sent to processing

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

grep, egrep, fgrep – 打印出匹配条件的文字行

sort

如果你想看这些log文件的内容,你可以把它们连接起来并输出到标准输出上,就是上面的例子展示的。这很有用,但输出的内容可以更有逻辑些。

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

8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99

正如他的名字所说的,你可以串联多个文件

8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99

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

jfields$ cat order* | sort | less

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

注意:下面的每个命令都有十分丰富的文档说明。这篇文章并不是来详尽的展示每个命令的各种功用的。我在这里要讲的是这几个最常用的命令的最常见用法。如果你对linux命令并不是很了解,你想找一些这方面的资料学习,那这篇文章将会给你一个基本的指导。

jfields$ cat order* | sort | less

【嵌牛正文】:

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

8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99

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

find

还是要先使用grep。

8:23:50 112, Order sent to fulfillment

–在目录里找文件

Users/jfields/order.in.log

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

现在,我们把数据缩减为我们计算想要的形式,把这些数据粘贴到Excel里立刻就能得到结果了。

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

jfields$ cat order.out.log

  每个开发人员到了他们职业人生的某个阶段的时候,将会发现自己要寻找有关Linux的信息。我并不是这方面的专家。但是掌握了以下8个Linux命令,我几乎可以得到我任何需要的东西。

8:23:45 112, 1, Joy of Clojure, Hardcover, 29.99

当然还有很多选项,但99%的情况下我这么做。

8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99

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

8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99

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

8:23:50 112, Order sent to fulfillment

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′

order.in.log

jfields$ find /Users -name "order*"

本文由金沙js333娱乐场发布于网络频道,转载请注明出处:金沙js333娱乐场:每个开发人员都应该知道的8个

关键词: