cut命令如何截取以空格隔開的字段


你的文件分隔符恐怕不止一個空格(一定的who生成的): 
用awk: 
awk '{print $2}' file 
一定要用cut的話: 
cat file|tr -s ' '|cut -d' ' -f2

 

通過使用 tr,您可以非常容易地實現 sed 的許多最基本功能。您可以將 tr 看作為 sed 的(極其)簡化的變體:它可以用一個字符來替換另一個字符,或者可以完全除去一些字符。您也可以用它來除去重復字符。這就是所有 tr 所能夠做的。  

 

tr -c -d -s ["string1_to_translate_from"] ["string2_to_translate_to"] < input-file
這里:
-c 用字符串1中字符集的補集替換此字符集,要求字符集為ASCII。(不怎么用到吧)
-d 刪除字符串1中所有輸入字符。
-s 刪除所有重復出現字符序列,只保留第一個;即將重復出現字符串壓縮為一個字符串。

可以有:

# cat file | tr "abc" "xyz" > new_file
 
【注意】這里,凡是在file中出現的"a"字母,都替換成"x"字母,"b"字母替換為"y"字母,"c"字母替換為"z"字母。而不是將字符串"abc"替換為字符串"xyz"。
 
2、使用tr命令“統一”字母大小寫
(小寫 --> 大寫)
# cat file | tr [a-z] [A-Z] > new_file
(大寫 --> 小寫)
# cat file | tr [A-Z] [a-z] > new_file
 
3、把文件中的數字0-9替換為a-j
 
# cat file | tr [0-9] [a-j] > new_file
4、刪除文件file中出現的"Snail"字符
 
# cat file | tr -d "Snail" > new_file
 
【注意】這里,凡是在file文件中出現的'S','n','a','i','l'字符都會被刪除!而不是緊緊刪除出現的"Snail”字符串。
 
5、刪除文件file中出現的換行'\n'、制表'\t'字符
 
# cat file | tr -d "\n\t" > new_file
 
不可見字符都得用轉義字符來表示的,這個都是統一的。
 
6、刪除“連續着的”重復字母,只保留第一個
 
# cat file | tr -s [a-zA-Z] > new_file
7、刪除空行
 
# cat file | tr -s "\n" > new_file
 
8、刪除Windows文件“造成”的'^M'字符
 
# cat file | tr -d "\r" > new_file
或者
# cat file | tr -s "\r" "\n" > new_file
 
【注意】這里-s后面是兩個參數"\r"和"\n",用后者替換前者
 
實驗了:

$ echo 'aabc' | tr -s 'a' 'd'

dbc

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM