十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
本篇文章為大家展示了Linux中如何使用 Cut命令,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
公司主營業(yè)務(wù):網(wǎng)站設(shè)計(jì)制作、網(wǎng)站設(shè)計(jì)、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出安新免費(fèi)做網(wǎng)站回饋大家。
Cut命令和語法
cut命令基本語法如下:
cut OPTION... [FILE]...
讓我們看一下這個(gè)選項(xiàng),沒有哪個(gè)選項(xiàng)此命令不起作用。
剪切選項(xiàng):
f:通過指定字段進(jìn)行提取。cut命令使用“ TAB”作為默認(rèn)字段分隔符。
d:'Tab'是默認(rèn)的分隔符,使用此選項(xiàng)可以使用特定的分隔符。
b:通過指定一個(gè)字節(jié)來提取。也可以指定字節(jié)范圍。
c:按字符分割。這可以是用逗號分隔的數(shù)字列表,也可以是用連字符(-)分隔的數(shù)字范圍。–complement:用來補(bǔ)充選擇
output-delimiter:要更改輸出分隔符,請使用選項(xiàng)-output-delimiter ='delimiter'。
-only-delimited:Cut將不會輸出不包含分隔符的行
在本教程中,我們將使用以下名為“ content.txt”的文本文件和/ etc / passwd文件來說明我們的示例。
$ cat content.txt Ubuntu Linux Microsoft Windows OsX El Capitan Unix FreeBSD
如何用分隔符剪切
最常用的cut選項(xiàng)是-d和-f的組合,它基本上會根據(jù)特定的分隔符和列出的字段提取內(nèi)容。
例如,以下僅使用分隔符(:)輸出'/ etc / passwd'文件中每行的第一字段。
$ cut -d':' -f1 /etc/passwd root bin daemon adm lp sync shutdown halt mail operator games ...
在下面的示例中,我們使用空格(“”)作為分隔符,并從名為'content.txt'的文件中刪除了第一個(gè)字段。
$ cut -d " " -f 1 content.txt Ubuntu Microsoft OsX Unix FreeBSD
本示例從特定文件中提取多個(gè)字段。在這里,我們使用冒號(:)分隔符從文件“ / etc / passwd”中提取第一和第六字段,文件中包含字符串“ / bin / bash”:
$ grep "/bin/bash" /etc/passwd | cut -d':' -f1,6 root:/root slax:/home/slax
要顯示字段范圍,請指定以hypen(-)分隔的開始字段和結(jié)束字段,如下所示:
$ 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
如何補(bǔ)充輸出選擇
要補(bǔ)充選擇字段列表,請使用--complement選項(xiàng)。此選項(xiàng)用于在何處選擇除指定字段以外的所有字段。
在下面的示例命令中,將輸出'/ etc / passwd'文件中第二個(gè)字段以外的所有字段:
$ grep "/bin/bash" /etc/passwd | cut -d':' --complement -f2 root:0:0:root:/root:/bin/bash
如何指定輸出分隔符:
要指定輸出分隔符,請使用--output-delimiter選項(xiàng)。輸入分隔符由-d選項(xiàng)指定,默認(rèn)情況下,輸出分隔符與輸入分隔符相同。
讓我們首先看下輸出不使用輸出分隔符的情況,如下所示:
$ 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
現(xiàn)在,我添加了--output-delimiter選項(xiàng),并將輸入分隔符冒號(:)替換為輸出分隔符“ 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
讓我們看下另一個(gè)示例,這里我們使用輸出分隔符輸出在新行的每個(gè)字段上。
在這里,我們將--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的文件的每一行輸出第一個(gè)字符,請使用以下命令:
$ cut -c 1 content.txt U M O U F
在下面的示例中,我們將顯示文件中每行的字符1至7(范圍):
$ cut -c 1-7 content.txt Ubuntu Microso OsX El Unix FreeBSD
讓我們看看如何通過特定的開始或結(jié)束位置來選擇列。
要將列從第二個(gè)字符提取到最后一個(gè)字符:
$ cut -c2- content.txt buntu Linux icrosoft Windows sX El Capitan nix reeBSD
要從第一個(gè)字符到第四個(gè)字符提取列:
cut -c-4 content.txt Ubun Micr OsX Unix Free
如何按照字節(jié)剪切
使用-b選項(xiàng)通過用逗號(,)分隔的數(shù)字指定字節(jié)位置來選擇一行中的一部分。使用連字符可以指定字節(jié)范圍。
以下示例從名為“ content.txt”的文件的第1、2和3個(gè)字節(jié)切出:
$ 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
一些實(shí)用的示例
Cut是結(jié)合不同的Linux或Unix命令最實(shí)用的方法。
例如,您要使用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-
讓我們再舉一個(gè)例子來提取內(nèi)存的“ total”、“ used”和“ free”值,并使用多個(gè)命令將其保存到文本文件中:
$ free -m | tr -s ' ' | sed '/^Mem/!d' | cut -d" " -f2-4 >> memory.txt Output $ cat memory.txt 985 86 234
結(jié)論
cut命令可以與許多其他Linux或Unix命令一起傳遞??梢酝ㄟ^管道傳遞一個(gè)或多個(gè)過濾器以進(jìn)行其他文本處理。
cut命令的局限性之一是它不支持指定多個(gè)字符作為分隔符。多個(gè)空格會被計(jì)為多個(gè)字段分隔符,必須在剪切前使用tr命令才能獲得所需的輸出。
上述內(nèi)容就是Linux中如何使用 Cut命令,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。