文本處理_分割_排序_統計_行編輯器

2017年1月10日, 星期二

文本處理_分割_排序_統計_行編輯器

文本文件:
Tom:23:male:2013/05/06

cut:
-d: 指定字段分隔符,默認是空格
-f: 指定要顯示的字段
-f 1,3
-f 1-3

文本排序:sort
-n:數值排序
-r: 降序
-t: 字段分隔符
-k: 以哪一個字段爲關鍵字進行排序
-u: 排序後相同的行只顯示一次
-f: 排序時忽略字符大小寫
文本統計:wc (word count)
-l
-w
-c
-L

sed基本用法:
sed: Stream EDitor
行編輯器 (全屏編輯器: vi)
sed: 模式空間
默認不編輯原文件,僅對模式空間中的數據作處理;然後,處理結束後,將模式空間打印至屏幕;


sed [options] 'AddressCommand' file ...
-n: 靜默模式,再也不默認顯示模式空間中的內容
-i: 直接修改原文件
-e SCRIPT -e SCRIPT:能夠同時執行多個腳本
-f /PATH/TO/SED_SCRIPT
sed -f /path/to/scripts  file
-r: 表示使用擴展正則表達式
Command:
d: 刪除符合條件的行;
p: 顯示符合條件的行;
a \string: 在指定的行後面追加新行,內容爲string
\n:能夠用於換行
i \string: 在指定的行前面添加新行,內容爲string
r FILE: 將指定的文件的內容添加至符合條件的行處
w FILE: 將地址指定的範圍內的行另存至指定的文件中; 
s/pattern/string/修飾符: 查找並替換,默認只替換每行中第一次被模式匹配到的字符串
加修飾符
g: 全局替換
i: 忽略字符大小寫
s///: s###, s@@@
\(\), \1, \2
l..e: like-->liker
 love-->lover
 
 like-->Like
 love-->Love
&: 引用模式匹配整個串

sed練習:
一、刪除/etc/grub.conf文件中行首的空白符;
sed -r 's@^[[:space:]]+@@g' /etc/grub.conf
二、替換/etc/inittab文件中"id:3:initdefault:"一行中的數字爲5;
sed 's@\(id:\)[0-9]\(:initdefault:\)@\15\2@g' /etc/inittab
三、刪除/etc/inittab文件中的空白行;
sed '/^$/d' /etc/inittab


相關文章
相關標籤/搜索