你的文件分隔符恐怕不止一個空格(一定的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
(大寫 --> 小寫)
# 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
或者
# cat file | tr -s "\r" "\n" > new_file
【注意】這里-s后面是兩個參數"\r"和"\n",用后者替換前者
實驗了:
$ echo 'aabc' | tr -s 'a' 'd'
dbc