sed本身是管线命令,可以分析standard input,可以将数据进行取代,删除,新增,撷取特定行等.
sed [-nefr] [action]
-n :使用 silent模式,只显示经过sed处理的行
-e :直接在命令行界面进行sed的动作编辑.
-f :直接将sed的动作写在一个文件内,-f filename 则可以执行filename内的sed动作.
-r :sed的动作支持的是延伸型正则表达式的语法.
-i :直接修改读取的文件内容而不是由屏幕输出.
-p :打印输出
action说明
[n1 [,n2]] function
n1,n2 :不一定存在,一般代表选择进行动作的行数.
function 说明
a :新增,a后接字串,这些字串会在目前行的下一行(新增)出现
c :取代,c后接字串,可以取代n1,n2之间的行
d :删除.不接东西.
i :插入,后接字串,在目前的上一行出现(新增).
s :取代.'sed s/要被取代的字符串/新的字符串/g'
sed -i 's/\/\/.*//' *.txt
去除所有的txt文件中的 //及之后的内容(直接更新文件)
awk
行处理命令,默认以空格为分界将一行分为多个项.
awk '条件类型1{动作1} 条件类型2{动作2}...' filename
例如
last -n 5 |awk '{print $1 "\t" $3}'
wang :0
reboot boot
wang :0
reboot boot
wang :0
wtmp Thu
0代表整行
awk内置变量
变量名称
代表意义
NF
每一行 ($0) 拥有的字段总数
NR
目前 awk 所处理的是“第几行”数据
FS
目前的分隔字符,默认是空白键
例如
last -n 5 | awk '{print $1 "\t lines: " NR "\t columes" NF}'
wang lines: 1 columes11
reboot lines: 2 columes10
wang lines: 3 columes10
reboot lines: 4 columes10
wang lines: 5 columes10
lines: 6 columes0
wtmp lines: 7 columes7
awk关键字
如果需要设置awk变量,可以使用BEGIN和END
例如
cat /etc/passwd | awk 'BEGIN {FS=":"} $3 < 10 {print $1 "\t " $3} '
root 0
daemon 1
bin 2
sys 3
sync 4
games 5
man 6
lp 7
mail 8
news 9
diff 文件比对.以行为单位.
diff [-bBi] source dest
-b : 忽略一行中,仅有多个空白的差异
-B : 忽略空白行的差异
-i : 忽略大小写的不同
cut -[bcdf] filename 从文件中提取所需信息的利器
参数说明
-b 以字节制定
cmp 以字节比较.
cmp [-l] file1 file2
-l 将所有不同点的字节处都列出来,默认只会输出第一个发现的不同点
这个基本不会用到,就不再写了
patch
补丁文件
patch -pN < patchfile
patch -R -pN < patchfile
-p : 后接代表"取消几层目录"的意思
-R : 代表还原,将亲的文件还原成原来旧的版本
printf 可以通过一些特殊符号来将数据进行格式化输出;
awk 可以使用“字段”为依据,进行数据的重新整理与输出;
文件的比对中,可利用 diff 及 cmp 进行比对,其中 diff 主要用在纯文本方面的新旧版本
比对
patch 指令可以将旧版数据更新到新版 (主要亦由 diff 创建 patch 的补丁来源文件)