Linux系統(tǒng)文本處理操作相關(guān)命令
文本處理
cat file1 file2 ... | command <> file1_in.txt_or_file1_out.txt general syntax for text manipulation using PIPE, STDIN and STDOUT
cat file1 | command( sed, grep, awk, grep, etc...) > result.txt
#合并一個(gè)文件的詳細(xì)說(shuō)明文本,并將簡(jiǎn)介寫(xiě)入一個(gè)新文件中
cat file1 | command( sed, grep, awk, grep, etc...) >> result.txt
#合并一個(gè)文件的詳細(xì)說(shuō)明文本,并將簡(jiǎn)介寫(xiě)入一個(gè)已有的文件中
grep Aug /var/log/messages #在文件 '/var/log/messages'中查找關(guān)鍵詞"Aug"
grep ^Aug /var/log/messages #在文件 '/var/log/messages'中查找以"Aug"開(kāi)始的詞匯
grep [0-9] /var/log/messages #選擇 '/var/log/messages' 文件中所有包含數(shù)字的行
grep Aug -R /var/log/* #在目錄 '/var/log' 及隨后的目錄中搜索字符串"Aug"
sed 's/stringa1/stringa2/g' example.txt
#將example.txt文件中的 "string1" 替換成 "string2"
sed '/^$/d' example.txt #從example.txt文件中刪除所有空白行
sed '/ *#/d; /^$/d' example.txt #從example.txt文件中刪除所有注釋和空白行
echo 'esempio' | tr '[:lower:]' '[:upper:]' #合并上下單元格內(nèi)容
sed -e '1d' result.txt #從文件example.txt 中排除第一行
sed -n '/stringa1/p' #查看只包含詞匯 "string1"的行
sed -e 's/ *$//' example.txt #刪除每一行最后的空白字符
sed -e 's/stringa1//g' example.txt
#從文檔中只刪除詞匯 "string1" 并保留剩余全部
sed -n '1,5p;5q' example.txt #查看從第一行到第5行內(nèi)容
sed -n '5p;5q' example.txt #查看第5行
sed -e 's/00*/0/g' example.txt #用單個(gè)零替換多個(gè)零
cat -n file1 #標(biāo)示文件的行數(shù)
cat example.txt | awk 'NR%2==1' #刪除example.txt文件中的所有偶數(shù)行
echo a b c | awk '{print $1}' #查看一行第一欄
echo a b c | awk '{print $1,$3}' #查看一行的第一和第三欄
paste file1 file2 #合并兩個(gè)文件或兩欄的內(nèi)容
paste -d '+' file1 file2 #合并兩個(gè)文件或兩欄的內(nèi)容,中間用"+"區(qū)分
sort file1 file2 #排序兩個(gè)文件的內(nèi)容
sort file1 file2 | uniq #取出兩個(gè)文件的并集(重復(fù)的行只保留一份)
sort file1 file2 | uniq -u #刪除交集,留下其他的行
sort file1 file2 | uniq -d #取出兩個(gè)文件的交集(只留下同時(shí)存在于兩個(gè)文件中的文件)
comm -1 file1 file2 #比較兩個(gè)文件的內(nèi)容只刪除 'file1' 所包含的內(nèi)容
comm -2 file1 file2 #比較兩個(gè)文件的內(nèi)容只刪除 'file2' 所包含的內(nèi)容
comm -3 file1 file2 #比較兩個(gè)文件的內(nèi)容只刪除兩個(gè)文件共有的部分