Linux中如何使用Cut命令

本篇文章为大家展示了Linux中如何使用 Cut命令,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

公司主营业务:网站设计制作、网站设计、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联推出安新免费做网站回馈大家。

Cut命令和语法

cut命令基本语法如下:

cut OPTION... [FILE]...

让我们看一下这个选项,没有哪个选项此命令不起作用。

剪切选项:

  • f:通过指定字段进行提取。cut命令使用“ TAB”作为默认字段分隔符。

  • d:'Tab'是默认的分隔符,使用此选项可以使用特定的分隔符。

  • b:通过指定一个字节来提取。也可以指定字节范围。

  • c:按字符分割。这可以是用逗号分隔的数字列表,也可以是用连字符(-)分隔的数字范围。–complement:用来补充选择

  • output-delimiter:要更改输出分隔符,请使用选项-output-delimiter ='delimiter'。

  • -only-delimited:Cut将不会输出不包含分隔符的行

在本教程中,我们将使用以下名为“ content.txt”的文本文件和/ etc / passwd文件来说明我们的示例。

$ cat content.txt  Ubuntu Linux Microsoft Windows OsX El Capitan Unix FreeBSD

如何用分隔符剪切

最常用的cut选项是-d和-f的组合,它基本上会根据特定的分隔符和列出的字段提取内容。

例如,以下仅使用分隔符(:)输出'/ etc / passwd'文件中每行的第一字段。

$ cut -d':' -f1 /etc/passwd root bin daemon adm lp sync shutdown halt mail operator games ...

在下面的示例中,我们使用空格(“”)作为分隔符,并从名为'content.txt'的文件中删除了第一个字段。

$ cut -d " " -f 1 content.txt  Ubuntu Microsoft OsX Unix FreeBSD

本示例从特定文件中提取多个字段。在这里,我们使用冒号(:)分隔符从文件“ / etc / passwd”中提取第一和第六字段,文件中包含字符串“ /  bin / bash”:

$ grep "/bin/bash" /etc/passwd | cut -d':' -f1,6 root:/root slax:/home/slax

要显示字段范围,请指定以hypen(-)分隔的开始字段和结束字段,如下所示:

$ grep "/bin/bash" /etc/passwd | cut -d':' -f1-4,6,7 root:x:0:0:/root:/bin/bash slax:x:1000:1000:/home/slax:/bin/bash

如何补充输出选择

要补充选择字段列表,请使用--complement选项。此选项用于在何处选择除指定字段以外的所有字段。

在下面的示例命令中,将输出'/ etc / passwd'文件中第二个字段以外的所有字段:

$ grep "/bin/bash" /etc/passwd | cut -d':' --complement -f2 root:0:0:root:/root:/bin/bash

如何指定输出分隔符:

要指定输出分隔符,请使用--output-delimiter选项。输入分隔符由-d选项指定,默认情况下,输出分隔符与输入分隔符相同。

让我们首先看下输出不使用输出分隔符的情况,如下所示:

$  cut -d: -f1,7  /etc/passwd |  sort |  uniq -u _apt:/usr/sbin/nologin backup:/usr/sbin/nologin bin:/usr/sbin/nologin daemon:/usr/sbin/nologin DNSmasq:/usr/sbin/nologin games:/usr/sbin/nologin gnats:/usr/sbin/nologin irc:/usr/sbin/nologin landscape:/usr/sbin/nologin list:/usr/sbin/nologin lp:/usr/sbin/nologin lxd:/bin/false

现在,我添加了--output-delimiter选项,并将输入分隔符冒号(:)替换为输出分隔符“ SPACE”,如下所示:

$  cut -d: -f1,7 --output-delimiter ' ' /etc/passwd |  sort |  uniq -u _apt /usr/sbin/nologin backup /usr/sbin/nologin bin /usr/sbin/nologin daemon /usr/sbin/nologin dnsmasq /usr/sbin/nologin games /usr/sbin/nologin gnats /usr/sbin/nologin irc /usr/sbin/nologin landscape /usr/sbin/nologin list /usr/sbin/nologin lp /usr/sbin/nologin lxd /bin/false

让我们看下另一个示例,这里我们使用输出分隔符输出在新行的每个字段上。

在这里,我们将--output-delimiter用作$’\ n’,表示新行。

输出如下:

$ grep root /etc/passwd | cut -d':' -f1,6,7 --output-delimiter=$'\n' root /root /bin/bash operator /root /sbin/nologin

如何按字符剪切

用于按字符位置剪切。请记住,“ TABS”和“空格”也被视为字符。

要从名为content.txt的文件的每一行输出第一个字符,请使用以下命令:

$ cut -c 1 content.txt U M O U F

在下面的示例中,我们将显示文件中每行的字符1至7(范围):

$ cut -c 1-7 content.txt Ubuntu Microso OsX El Unix FreeBSD

让我们看看如何通过特定的开始或结束位置来选择列。

要将列从第二个字符提取到最后一个字符:

$ cut -c2- content.txt buntu Linux icrosoft Windows sX El Capitan nix reeBSD

要从第一个字符到第四个字符提取列:

cut -c-4 content.txt Ubun Micr OsX Unix Free

如何按照字节剪切

使用-b选项通过用逗号(,)分隔的数字指定字节位置来选择一行中的一部分。使用连字符可以指定字节范围。

以下示例从名为“ content.txt”的文件的第1、2和3个字节切出:

$ cut -b 1,2,3 content.txt  Ubu Mic OsX Uni Fre

我们还可以使用以下命令列出范围:

$ cut -b 1-3,5-7 content.txt  Ubutu  Micoso OsXEl  Uni FreBSD

一些实用的示例

Cut是结合不同的Linux或Unix命令最实用的方法。

例如,您要使用ps命令提取“ USER”,“ PID”和“ COMMAND”如下:

 ps -L u n | tr -s " " | cut -d " " -f 2,3,14- USER PID COMMAND 0 676 /sbin/agetty -o -p -- \u --keep-baud 115200,38400,9600 ttyS0 vt220 0 681 /sbin/agetty -o -p -- \u --noclear tty1 linux 0 23174 -bash 0 26737 ps -L u n 0 26738 tr -s 0 26739 cut -d -f 2,3,14-

让我们再举一个例子来提取内存的“ total”、“ used”和“ free”值,并使用多个命令将其保存到文本文件中:

$ free -m | tr -s ' ' | sed '/^Mem/!d' | cut -d" " -f2-4 >> memory.txt Output $ cat memory.txt 985 86 234

结论

cut命令可以与许多其他Linux或Unix命令一起传递。可以通过管道传递一个或多个过滤器以进行其他文本处理。

cut命令的局限性之一是它不支持指定多个字符作为分隔符。多个空格会被计为多个字段分隔符,必须在剪切前使用tr命令才能获得所需的输出。

上述内容就是Linux中如何使用 Cut命令,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


本文名称:Linux中如何使用Cut命令
分享路径:http://pcwzsj.com/article/psohdi.html