- 浏览: 51252 次
- 性别:
- 来自: 深圳
最新评论
awk命令简介
在shell命令或编程中,可以用AWK强大的的文本处理能力。如果要格式化报文或从一个大的文本文件中抽取数据包,那么awk可完成这些任务。awk是一种解释的编程语言。awk也是shell过滤工具中最难掌握的。awk是一种自解释的编程语言。结合awk和sed和grep,将会使awk编程更加容易。
awk语言最基本的功能是在文件或字符串中基于指定的规则浏览和抽取信息。
有三种方式可调用awk.
<1>.命令行方式。
<2>.将所有的awk命令插入一个文件,并利用chmod使awk文件成为执行。
<3>.将所有的awk命令插入一个单独文件,然后调用。
以下简单介绍awk的各种方式,详细请查看相关另外文档
在awk中有四种概念。
1.抽取域
2.匹配正则表达式
3.比较域
4.向awk传递参数
以下简单介绍:
1).保存awk输出: #awk \'{print $0}\' myfile>newfile
2).使用tee,在输出到文件的同时输出到屏幕(利用管道\'|\')
#awk \'{print $0}\' myfile |tee newfile
3).打印报告头,#awk \'BEGIN {print hello,this is Titlen---------}{print $0}\' newfile
4).打印信息尾.#awk \'BEGIN{print $0} END {end of file.}\' myfile
5).匹配,如下若在myfile第二列中带有BROWN,则打印信息
#awk \'{if ($2~/BROWN/) print $0}\' myfile
6).精确匹配,同上,只是将~改为==
7).不匹配,有时要浏览信息并抽取不匹配操作的记录,与~相反的符号是!,如下
#awk \'$0 !~/BROWN/\' myfile
8).比较
如小于: #awk \'if ($1<$2) print $1\' myfile
9).设置大小写 #awk \'[Gg]reen/\' myfile
10).任意字符,表达式/^...a/意为前三个字符是任意字符
//-------------------------------------------------------
linux tee 命令详解
功能说明:读取标准输入的数据,并将其内容输出成文件。
语 法:tee [-ai][--help][--version][文件...]
补充说明:tee指令会从标准输入设备读取数据,将其内容输出到标准输出设备,同时保存成文件。
参 数:
-a或--append 附加到既有文件的后面,而非覆盖它.
-i-i或--ignore-interrupts 忽略中断信号。
--help 在线帮助。
--version 显示版本信息。
//--------------------------------------------------------------------------------------
Sed 命令列可分成编辑指令与文件档部份。其中 , 编辑指令负责控制所有的编辑工作 ; 文件档表示所处理的档案。
sed 的编辑指令均由位址(address)与函数(function)两部份组成 , 其中 , 在执行时 , sed 利用它的位址参数来
决定编辑的对象;而用它的函数参数(解[3])编辑。
此外 , sed 编辑指令 , 除了可在命令列上执行 , 也可在档案内执行。其中差别只是在命令列上执行时 , 其前必
须加上选项 -e ; 而在档案(解[4])内时 , 则只需在其档名前加上选项 -f。另外 , sed 执行编辑指令是依照它
们在命令列上或档内的次序。
下面各节 , 将介绍执行命令列上的编辑指令 、sed 编辑指令、执行档案内的编辑指令、执行多个档案的编辑、及
执行 sed 输出控制。
2.1 执行命令列上的编辑指令
2.2 sed 编辑指令
2.3 执行档案内的编辑指令
2.4 执行多个档案的编辑
2.5 执行 sed 输出控制
2.1.执行命令列上的编辑指令
当编辑指令(参照[section 2.2])在命令列上执行时 , 其前必须加上选项 -e 。其命令格式如下 :
sed -e \'编辑指令1\' -e \'编辑指令2\' ... 文件档
其中 , 所有编辑指令都紧接在选项 -e 之後 , 并置於两个 \' 特殊字元间。另外 , 命令上编辑指令的执行是由
左而右。
一般编辑指令不多时 , 使用者通常直接在命令上执行它们。例如 , 删除 yel.dat 内 1 至 10 行资料 , 并将其
馀文字中的 yellow 字串改成 black 字串。此时 , 可将编辑指令直接在命令上执行 , 其命令如下 :
sed -e \'1,10d\' -e \'s/yellow/black/g\' yel.dat
在命令中 , 编辑指令 \'1,10d\'(解[5])执行删除 1 至 10 行资料 ; 编辑指令 \'s/yellow/black/g\'(解[6]) ,
yellow 字串替换(substuite)成 black 字串。
2.2 sed 的编辑指令
sed 编辑指令的格式如下 :
[address1[,address2]]function[argument]
其中 , 位址参数 address1 、address2 为行数或 regular expression 字串 , 表示所执行编辑的资料行 ; 函数参
数 function[argument] 为 sed 的内定函数 , 表示执行的编辑动作。
下面两小节 , 将仔细介绍位址参数的表示法与有哪些函数参数供选择。
2.2.1 位址(address)参数的表示法
实际上 , 位址参数表示法只是将要编辑的资料行 , 用它们的行数或其中的字串来代替表示它们。下面举几个例子
说明(指令都以函数参数 d(参照[section4.2]) 为例) :
删除档内第 10 行资料 , 则指令为 10d。
删除含有 man 字串的资料行时 , 则指令为 /man/d。
删除档内第 10 行到第 200 行资料, 则指令为 10,200d。
删除档内第 10 行到含 man 字串的资料行 , 则指令为 10,/man/d。
接下来 , 以位址参数的内容与其个数两点 , 完整说明指令中位址参数的表示法(同样也以函数参数 d 为例)。
位址参数的内容:
位址为十进位数字 : 此数字表示行数。当指令执行时 , 将对符合此行数的资料执行函数参数指示的编辑动作。例如 ,
删除资料档中的第 15 行资料 , 则指令为 15d(参照[section4.2])。其馀类推 ,如删除资料档中的第 m 行资料 , 则
指令为 md 。
位址为 regular expression(参照[附录 A]):
当资料行中有符合 regular expression 所表示的字串时 , 则执行函数参数指示的编辑动作。另外 , 在
regular expression 前後必须加上 /。例如指令为 /t.*t/d , 表示删除所有含两 t 字母的资料行。其中 , .
表示任意字元; * 表示其前字元可重任意次 , 它们结合 .* 表示两 t 字母间的任意字串。
位址参数的个数 : 在指令中 , 当没有位址参数时 , 表示全部资料行执行函数参数所指示的编辑动作; 当只有一位址
参数时 , 表示只有符合位址的资料行才编辑 ; 当有两个位址参数 , 如 address1,address2 时 , 表示对资料区执行
编辑 , address1 代表起始资料行 , address2 代表结束资料行。对於上述内容 , 以下面例子做具说明。
例如指令为
d
其表示删除档内所有资料行。
例如指令为
5d
其表示删除档内第五行资料。
例如指令为
1,/apple/d
其表示删除资料区 , 由档内第一行至内有 apple 字串的资料行。
例如指令为
/apple/,/orange/d
其表示删除资料区 , 由档内含有 apple 字串至含有 orange 字串的资料行
2.2.2 有那些函数(function)参数
下页表中介绍所有 sed 的函数参数(参照[chapter 4])的功能。
函数参数 功能
: label 建立 script file 内指令互相参考的位置。
# 建立解
{ } 集合有相同位址参数的指令。
! 不执行函数参数。
= 印出资料行数( line number )。
a 添加使用者输入的资料。
b label 将执行的指令跳至由 : 建立的参考位置。
c 以使用者输入的资料取代资料。
d 删除资料。
D 删除 pattern space 内第一个 newline 字母 前的资料。
g 拷贝资料从 hold space。
G 添加资料从 hold space 至 pattern space 。
h 拷贝资料从 pattern space 至 hold space 。
H 添加资料从 pattern space 至 hold space 。
l 印出 l 资料中的 nonprinting character 用 ASCII 码。
i 插入添加使用者输入的资料行。
n 读入下一笔资料。
N 添加下一笔资料到 pattern space。
p 印出资料。
P 印出 pattern space 内第一个 newline 字母 前的资料。
q 跳出 sed 编辑。
r 读入它档内容。
s 替换字串。
t label 先执行一替换的编辑指令 , 如果替换成牛p>则将编辑指令跳至 : label 处执行。
w 写资料到它档内。
x 交换 hold space 与 pattern space 内容。
y 转换(transform)字元。
虽然 , sed 只有上表所述几个拥有基本编辑功能的函数 , 但由指令中位址参数和指令与指令间的配合 , 也能使
sed 完成大部份的编辑任务。
2.3 执行档案内的编辑指令
当执行的指令太多 , 在命令列上撰写起来十分混乱 , 此时 , 可将这些指令整理储存在档案
(譬如档名为 script_file )内 , 用选项 -f script_file , 则让 sed 执行 script_file 内的编辑指令。其命
令的格示如下 :
sed -f script_file 文件档
其中 , 执行 script_file 内编辑指令的顺序是由上而下。例如上一节的例子 , 其可改成如下命令:
sed -f ysb.scr yel.dat
其中 , ysb.scr 档的内容如下 :
1,10d
s/yellow/black/g
另外 , 在命令列上可混合使用选项 -e 与 -f , sed 执行指令顺序依然是由命令列的左到右, 如执行至 -f 後
档案内的指令 , 则由上而下执行。http://www.linuxso.com/command/tee.html
2.4 执行多个文件档的编辑
在 sed 命令列上 , 一次可执行编辑多个文件档 , 它们跟在编辑指令之後。例如 , 替换
white.dat、red.dat、black.dat 档内的 yellow 字串成 blue , 其命令如下:
sed -e \'s/yellow/blue/g\' white.dat red.dat black.dat
上述命令执行时 , sed 依 white.dat、red.dat、black.dat 顺序 , 执行编辑指令 s/yellow/blue/(请参照[section 4.1] ,
进行字串的替换。
2.5.执行输出的控制
在命令列上的选项 -n (解[7]) 表示输出由编辑指令控制。由前章内容得知 , sed 会 自动的 将资料由
pattern space 输送到标准输出档。但藉着选项 -n , 可将 sed 这 自动的 的动作改成 被动的 由它所执行的
编辑指令(解[8])来决定结果是否输出。
由上述可知 , 选项 -n 必须与编辑指令一起配合 , 否则无法获得结果。例如 , 印出 white.dat 档内含有 white
字串的资料行 , 其命令如下:
sed -n -e \'/white/p\' white.dat
上面命令中 , 选项 -n 与编辑指令 /white/p (参照[section4.6]) 一起配合控制输出。其中 , 选项 -n 将输出控制权
移给编辑指令;/white/p 将资料行中含有 white 字串印出萤幕。
#awk \'$1~/^...a/\' myfile
11).或关系匹配,#awk \'$0~/(YELLOW || RED)/\' myfile
12).与:&& ,或:||
13).awk内置变量
<1>.要快速查看记录个数,应使用NR,如:#awk \'END {print NR}\' myfile <2>.以下使用NF变量显示每一条读记录中有多少个域,并在END部份 打印输入文件名。#awk \'{print NR,NF,$0} END {print FILENAME}\' myfile
<3>. 判断并输出 . #awk \'{if(NR>0 && $4~/BROWN/) print $0\' myfile
14).可以设置输入域到域变量名。
15).域值比较操作。
@1.在BEGIN中给变量名赋值。通常在BEGIN部分赋值是很有益的,可以在awk表达式进行改动时减少很大麻烦.
@2.在关系操作中使用实际数值,使用关系操作时必须用括号括起来.
#awk \'{if($6<27) print $0}\' myfile
#awk \'BEGIN {BASELINE=27}{if ($6<BASELINE) print $6}\' myfile
17).修改数据域取值
当在awk中修改任何域时,重要的一点是实际的文件可修改,改动的是cache中的awk复本,awk会在变量NR或NF中反映出修改的痕迹。
#awk \'{if($1==M.TANS)$6=$6-1;print $6}\' myfile
18).修改文本域
#awk \'{if($1==J.Troll)($1=J.L.Troll);print $1}\' myfile
19).只显示修改记录
#awk \'{if($1==J.Troll){$1=J.L.Troll;print $1}}\' myfile
20).创建新的输出域
在awk中处理数据时,基于各域进行计算的创建新域是个好的习惯。如下示例:
#awk \'BEGIN{print Name Scoret}if($6<$7){$8=$7-$6;print $8}\' myfile
21).增加列值
#awk \'tot+=$6;END{print Club Total point. tot}\' myfile
22).使用模式打印文件名及其长度,放入变量tot中
#ls -l | awk\'/^[^d]{print $9 t $5}{tot+=$5} END {print Total KB:tot}\'
23).awk内置的字符串函数
24).awk脚本文件
如以上的所述的诸多情况,这里只不过命令放在一个文件中,且该文件必须是!/bin/awk -f ,因为这样才会使这个文件可以自解释。否则将不能作用。为了容易分别,最好将文件带一个扩展名.awk,完成对文件的编写后,再利用chmod u+x使文件可以执行。
以上只是我在实验中的一些情况,awk命令功能很强大,大家可以参考其它的一些手册去获得更清楚的说明
http://www.linuxso.com/command/tee.html
在shell命令或编程中,可以用AWK强大的的文本处理能力。如果要格式化报文或从一个大的文本文件中抽取数据包,那么awk可完成这些任务。awk是一种解释的编程语言。awk也是shell过滤工具中最难掌握的。awk是一种自解释的编程语言。结合awk和sed和grep,将会使awk编程更加容易。
awk语言最基本的功能是在文件或字符串中基于指定的规则浏览和抽取信息。
有三种方式可调用awk.
<1>.命令行方式。
<2>.将所有的awk命令插入一个文件,并利用chmod使awk文件成为执行。
<3>.将所有的awk命令插入一个单独文件,然后调用。
以下简单介绍awk的各种方式,详细请查看相关另外文档
在awk中有四种概念。
1.抽取域
2.匹配正则表达式
3.比较域
4.向awk传递参数
以下简单介绍:
1).保存awk输出: #awk \'{print $0}\' myfile>newfile
2).使用tee,在输出到文件的同时输出到屏幕(利用管道\'|\')
#awk \'{print $0}\' myfile |tee newfile
3).打印报告头,#awk \'BEGIN {print hello,this is Titlen---------}{print $0}\' newfile
4).打印信息尾.#awk \'BEGIN{print $0} END {end of file.}\' myfile
5).匹配,如下若在myfile第二列中带有BROWN,则打印信息
#awk \'{if ($2~/BROWN/) print $0}\' myfile
6).精确匹配,同上,只是将~改为==
7).不匹配,有时要浏览信息并抽取不匹配操作的记录,与~相反的符号是!,如下
#awk \'$0 !~/BROWN/\' myfile
8).比较
如小于: #awk \'if ($1<$2) print $1\' myfile
9).设置大小写 #awk \'[Gg]reen/\' myfile
10).任意字符,表达式/^...a/意为前三个字符是任意字符
//-------------------------------------------------------
linux tee 命令详解
功能说明:读取标准输入的数据,并将其内容输出成文件。
语 法:tee [-ai][--help][--version][文件...]
补充说明:tee指令会从标准输入设备读取数据,将其内容输出到标准输出设备,同时保存成文件。
参 数:
-a或--append 附加到既有文件的后面,而非覆盖它.
-i-i或--ignore-interrupts 忽略中断信号。
--help 在线帮助。
--version 显示版本信息。
//--------------------------------------------------------------------------------------
Sed 命令列可分成编辑指令与文件档部份。其中 , 编辑指令负责控制所有的编辑工作 ; 文件档表示所处理的档案。
sed 的编辑指令均由位址(address)与函数(function)两部份组成 , 其中 , 在执行时 , sed 利用它的位址参数来
决定编辑的对象;而用它的函数参数(解[3])编辑。
此外 , sed 编辑指令 , 除了可在命令列上执行 , 也可在档案内执行。其中差别只是在命令列上执行时 , 其前必
须加上选项 -e ; 而在档案(解[4])内时 , 则只需在其档名前加上选项 -f。另外 , sed 执行编辑指令是依照它
们在命令列上或档内的次序。
下面各节 , 将介绍执行命令列上的编辑指令 、sed 编辑指令、执行档案内的编辑指令、执行多个档案的编辑、及
执行 sed 输出控制。
2.1 执行命令列上的编辑指令
2.2 sed 编辑指令
2.3 执行档案内的编辑指令
2.4 执行多个档案的编辑
2.5 执行 sed 输出控制
2.1.执行命令列上的编辑指令
当编辑指令(参照[section 2.2])在命令列上执行时 , 其前必须加上选项 -e 。其命令格式如下 :
sed -e \'编辑指令1\' -e \'编辑指令2\' ... 文件档
其中 , 所有编辑指令都紧接在选项 -e 之後 , 并置於两个 \' 特殊字元间。另外 , 命令上编辑指令的执行是由
左而右。
一般编辑指令不多时 , 使用者通常直接在命令上执行它们。例如 , 删除 yel.dat 内 1 至 10 行资料 , 并将其
馀文字中的 yellow 字串改成 black 字串。此时 , 可将编辑指令直接在命令上执行 , 其命令如下 :
sed -e \'1,10d\' -e \'s/yellow/black/g\' yel.dat
在命令中 , 编辑指令 \'1,10d\'(解[5])执行删除 1 至 10 行资料 ; 编辑指令 \'s/yellow/black/g\'(解[6]) ,
yellow 字串替换(substuite)成 black 字串。
2.2 sed 的编辑指令
sed 编辑指令的格式如下 :
[address1[,address2]]function[argument]
其中 , 位址参数 address1 、address2 为行数或 regular expression 字串 , 表示所执行编辑的资料行 ; 函数参
数 function[argument] 为 sed 的内定函数 , 表示执行的编辑动作。
下面两小节 , 将仔细介绍位址参数的表示法与有哪些函数参数供选择。
2.2.1 位址(address)参数的表示法
实际上 , 位址参数表示法只是将要编辑的资料行 , 用它们的行数或其中的字串来代替表示它们。下面举几个例子
说明(指令都以函数参数 d(参照[section4.2]) 为例) :
删除档内第 10 行资料 , 则指令为 10d。
删除含有 man 字串的资料行时 , 则指令为 /man/d。
删除档内第 10 行到第 200 行资料, 则指令为 10,200d。
删除档内第 10 行到含 man 字串的资料行 , 则指令为 10,/man/d。
接下来 , 以位址参数的内容与其个数两点 , 完整说明指令中位址参数的表示法(同样也以函数参数 d 为例)。
位址参数的内容:
位址为十进位数字 : 此数字表示行数。当指令执行时 , 将对符合此行数的资料执行函数参数指示的编辑动作。例如 ,
删除资料档中的第 15 行资料 , 则指令为 15d(参照[section4.2])。其馀类推 ,如删除资料档中的第 m 行资料 , 则
指令为 md 。
位址为 regular expression(参照[附录 A]):
当资料行中有符合 regular expression 所表示的字串时 , 则执行函数参数指示的编辑动作。另外 , 在
regular expression 前後必须加上 /。例如指令为 /t.*t/d , 表示删除所有含两 t 字母的资料行。其中 , .
表示任意字元; * 表示其前字元可重任意次 , 它们结合 .* 表示两 t 字母间的任意字串。
位址参数的个数 : 在指令中 , 当没有位址参数时 , 表示全部资料行执行函数参数所指示的编辑动作; 当只有一位址
参数时 , 表示只有符合位址的资料行才编辑 ; 当有两个位址参数 , 如 address1,address2 时 , 表示对资料区执行
编辑 , address1 代表起始资料行 , address2 代表结束资料行。对於上述内容 , 以下面例子做具说明。
例如指令为
d
其表示删除档内所有资料行。
例如指令为
5d
其表示删除档内第五行资料。
例如指令为
1,/apple/d
其表示删除资料区 , 由档内第一行至内有 apple 字串的资料行。
例如指令为
/apple/,/orange/d
其表示删除资料区 , 由档内含有 apple 字串至含有 orange 字串的资料行
2.2.2 有那些函数(function)参数
下页表中介绍所有 sed 的函数参数(参照[chapter 4])的功能。
函数参数 功能
: label 建立 script file 内指令互相参考的位置。
# 建立解
{ } 集合有相同位址参数的指令。
! 不执行函数参数。
= 印出资料行数( line number )。
a 添加使用者输入的资料。
b label 将执行的指令跳至由 : 建立的参考位置。
c 以使用者输入的资料取代资料。
d 删除资料。
D 删除 pattern space 内第一个 newline 字母 前的资料。
g 拷贝资料从 hold space。
G 添加资料从 hold space 至 pattern space 。
h 拷贝资料从 pattern space 至 hold space 。
H 添加资料从 pattern space 至 hold space 。
l 印出 l 资料中的 nonprinting character 用 ASCII 码。
i 插入添加使用者输入的资料行。
n 读入下一笔资料。
N 添加下一笔资料到 pattern space。
p 印出资料。
P 印出 pattern space 内第一个 newline 字母 前的资料。
q 跳出 sed 编辑。
r 读入它档内容。
s 替换字串。
t label 先执行一替换的编辑指令 , 如果替换成牛p>则将编辑指令跳至 : label 处执行。
w 写资料到它档内。
x 交换 hold space 与 pattern space 内容。
y 转换(transform)字元。
虽然 , sed 只有上表所述几个拥有基本编辑功能的函数 , 但由指令中位址参数和指令与指令间的配合 , 也能使
sed 完成大部份的编辑任务。
2.3 执行档案内的编辑指令
当执行的指令太多 , 在命令列上撰写起来十分混乱 , 此时 , 可将这些指令整理储存在档案
(譬如档名为 script_file )内 , 用选项 -f script_file , 则让 sed 执行 script_file 内的编辑指令。其命
令的格示如下 :
sed -f script_file 文件档
其中 , 执行 script_file 内编辑指令的顺序是由上而下。例如上一节的例子 , 其可改成如下命令:
sed -f ysb.scr yel.dat
其中 , ysb.scr 档的内容如下 :
1,10d
s/yellow/black/g
另外 , 在命令列上可混合使用选项 -e 与 -f , sed 执行指令顺序依然是由命令列的左到右, 如执行至 -f 後
档案内的指令 , 则由上而下执行。http://www.linuxso.com/command/tee.html
2.4 执行多个文件档的编辑
在 sed 命令列上 , 一次可执行编辑多个文件档 , 它们跟在编辑指令之後。例如 , 替换
white.dat、red.dat、black.dat 档内的 yellow 字串成 blue , 其命令如下:
sed -e \'s/yellow/blue/g\' white.dat red.dat black.dat
上述命令执行时 , sed 依 white.dat、red.dat、black.dat 顺序 , 执行编辑指令 s/yellow/blue/(请参照[section 4.1] ,
进行字串的替换。
2.5.执行输出的控制
在命令列上的选项 -n (解[7]) 表示输出由编辑指令控制。由前章内容得知 , sed 会 自动的 将资料由
pattern space 输送到标准输出档。但藉着选项 -n , 可将 sed 这 自动的 的动作改成 被动的 由它所执行的
编辑指令(解[8])来决定结果是否输出。
由上述可知 , 选项 -n 必须与编辑指令一起配合 , 否则无法获得结果。例如 , 印出 white.dat 档内含有 white
字串的资料行 , 其命令如下:
sed -n -e \'/white/p\' white.dat
上面命令中 , 选项 -n 与编辑指令 /white/p (参照[section4.6]) 一起配合控制输出。其中 , 选项 -n 将输出控制权
移给编辑指令;/white/p 将资料行中含有 white 字串印出萤幕。
#awk \'$1~/^...a/\' myfile
11).或关系匹配,#awk \'$0~/(YELLOW || RED)/\' myfile
12).与:&& ,或:||
13).awk内置变量
<1>.要快速查看记录个数,应使用NR,如:#awk \'END {print NR}\' myfile <2>.以下使用NF变量显示每一条读记录中有多少个域,并在END部份 打印输入文件名。#awk \'{print NR,NF,$0} END {print FILENAME}\' myfile
<3>. 判断并输出 . #awk \'{if(NR>0 && $4~/BROWN/) print $0\' myfile
14).可以设置输入域到域变量名。
15).域值比较操作。
@1.在BEGIN中给变量名赋值。通常在BEGIN部分赋值是很有益的,可以在awk表达式进行改动时减少很大麻烦.
@2.在关系操作中使用实际数值,使用关系操作时必须用括号括起来.
#awk \'{if($6<27) print $0}\' myfile
#awk \'BEGIN {BASELINE=27}{if ($6<BASELINE) print $6}\' myfile
17).修改数据域取值
当在awk中修改任何域时,重要的一点是实际的文件可修改,改动的是cache中的awk复本,awk会在变量NR或NF中反映出修改的痕迹。
#awk \'{if($1==M.TANS)$6=$6-1;print $6}\' myfile
18).修改文本域
#awk \'{if($1==J.Troll)($1=J.L.Troll);print $1}\' myfile
19).只显示修改记录
#awk \'{if($1==J.Troll){$1=J.L.Troll;print $1}}\' myfile
20).创建新的输出域
在awk中处理数据时,基于各域进行计算的创建新域是个好的习惯。如下示例:
#awk \'BEGIN{print Name Scoret}if($6<$7){$8=$7-$6;print $8}\' myfile
21).增加列值
#awk \'tot+=$6;END{print Club Total point. tot}\' myfile
22).使用模式打印文件名及其长度,放入变量tot中
#ls -l | awk\'/^[^d]{print $9 t $5}{tot+=$5} END {print Total KB:tot}\'
23).awk内置的字符串函数
24).awk脚本文件
如以上的所述的诸多情况,这里只不过命令放在一个文件中,且该文件必须是!/bin/awk -f ,因为这样才会使这个文件可以自解释。否则将不能作用。为了容易分别,最好将文件带一个扩展名.awk,完成对文件的编写后,再利用chmod u+x使文件可以执行。
以上只是我在实验中的一些情况,awk命令功能很强大,大家可以参考其它的一些手册去获得更清楚的说明
http://www.linuxso.com/command/tee.html
发表评论
-
[转]Linux下查看文件和文件夹大小的df和du命令
2012-08-13 10:54 945当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是 ... -
编译程序的.deps目录和.Po文件作用
2012-08-04 17:46 0当使用由automake产生的Makefile文件编译程序时, ... -
[转]Linux信号量 sem_t简介
2012-08-02 08:03 3606信号量的数据类型为结构sem_t,它本质上是一个长整型的数。函 ... -
Linux编译安装软件过程中设置环境变量
2012-07-31 20:28 3287Linux下很多软件需要自己由源代码编译出才能使用,特别是使用 ... -
profile bashrc bash_profile 之间的区别和联系【转】
2012-07-31 19:51 1365/etc/profile:此文件为系统 ... -
[转]Vim+cscope+ctags+tags阅读源代码
2012-03-23 10:06 1391[size=small]linux源代码提供了制作cscope ... -
[转]在Linux下编译OpenJdk并调试Hotspot
2012-03-23 09:18 4199背景 对于大多数Java程序员来说,JVM就是一个黑盒子,我 ... -
linux头文件和库文件设置问题
2012-03-22 10:01 1640当初在编译时指定的(在~gcc/gcc/collect2.c: ... -
基本 yum 命令和用法
2012-03-20 16:27 1771Page 1 基本 yum 命令和用 ... -
yum命令
2012-03-20 16:22 935yum check-update 检查可更新的所有软件包 y ... -
CentOS yum源
2012-03-20 15:39 10001.如何设置CentOS 5的yum源为上海交通大学网站 修 ...
相关推荐
tee命令是一个实用工具,它可以从标准输入接收数据,同时将数据输出到标准输出和指定的文件。这允许用户在保存输出的同时在屏幕上查看输出。 1. **基本用法**:`tee [-ai][---help][---version][文件...]` - `-a` ...
38. **tee** - 读取标准输入并写入文件。 39. **tmpwatch** - 清理临时文件。 40. **touch** - 修改文件的时间戳或创建空文件。 41. **umask** - 设置新建文件的默认权限掩码。 42. **which** - 查找可执行文件的...
### Linux常用命令详解 #### 一、文件管理 在Linux系统中,文件管理是一系列重要的操作,涵盖了创建、查看、编辑、分割等各个方面。本文将详细介绍一些常用的文件管理命令。 ##### 1. tee **功能说明:** 读取...
- **TEE**: 用于将标准输入同时写入标准输出和一个或多个文件。 - **TMPWATCH (Temporary Watch)**: 用于监控和清理临时文件。 - **TOUCH**: 用于更改文件的时间戳或创建新文件。 - **UMASK**: 用于设置文件和目录的...
Linux tee命令用于读取标准输入的数据,并将其内容输出成文件。 tee指令会从标准输入设备读取数据,将其内容输出到标准输出设备,同时保存成文件。 tee [-ai][--help][--version][文件...] 参数:
- **tee命令**:`tee`命令可以将标准输入的内容输出到屏幕的同时也保存到文件中。 #### 八、shell的特性与扩展 - **字符展开**:shell支持多种类型的字符展开,如通配符展开、路径名展开等。 - **命令替换**:使用...
### Linux指令学习知识点详解 #### 一、基本概念与常用指令 **1.1 时间相关指令** - **date**: 显示或设置系统日期和时间。此命令可以用来获取当前的日期和时间信息,也可以用于设置系统的时间。例如,`date` ...
- **`tee`**:读取标准输入并写入标准输出和文件。 - **`basename`**:移除路径中的目录名。 - **`dirname`**:提取路径中的目录名。 - **`head`**:显示文件的头部。 - **`tail`**:显示文件的尾部。 - **`...
- `tee`:读取标准输入并写入标准输出和文件。 - `basename`:返回文件名,去除路径前缀。 - `dirname`:返回文件所在的目录名。 - `head`:显示文件的前几行。 - `tail`:显示文件的后几行。 #### 总结 通过上述...
20. **tee**: 读取标准输入并将数据写入文件和标准输出。 21. **xargs**: 从标准输入读取数据并执行命令。 22. **fg**: 将后台任务移到前台执行。 23. **bg**: 将暂停的任务放到后台继续执行。 通过上述命令的学习...
### Linux Shell脚本编写基础知识点详解 #### 一、引言 在Linux环境中,Shell脚本是一种非常重要的自动化工具,广泛应用于系统管理、任务调度、软件部署等多个领域。对于初学者来说,掌握基本的Shell脚本编写技巧是...
在Linux操作系统中,输入输出重定向是控制命令执行时输出流向的重要工具,它允许我们将原本输出到屏幕的信息重定向到文件或设备,甚至其他命令。本文将深入解析Linux中的输入输出重定向及其常见用法。 1. 输出...
- **tee**:读取标准输入并将其写入文件。 - 示例:`echo "Hello, World!" | tee output.txt` - 将 `echo` 命令的输出同时写入 `output.txt` 文件。 - **basename** 和 **dirname**:操作文件名。 - 示例:`...
### 使用Shell命令进行数据读取与输出详解 在日常的系统管理和编程工作中,Shell脚本是一种非常实用且强大的工具,它能够帮助我们高效地完成各种任务。本文将深入讲解如何利用Shell命令进行数据的读取与输出操作,...
本文从Shell的基本概念入手,逐步深入到Bash脚本的编写技巧,涵盖了变量的定义与使用、常用Shell命令的操作方法以及复杂的管道和重定向操作。通过这些知识点的学习,读者不仅可以掌握Bash脚本的基础知识,还能学会...
- **管道操作**:`|` 用于将前一个命令的输出作为后一个命令的输入,通常与 `tee` 命令结合使用,以便同时显示和保存输出结果。 #### 四、常用命令后缀 - `-a`:显示所有内容(all)。 - `-e`:显示所有内容,比 `...
### 基本Unix命令详解 #### 一、基本概念介绍 在Unix系统中,命令行是最基础也是最强大的操作工具之一。通过一系列简洁而功能强大的命令,用户能够高效地管理文件、目录以及进行系统配置等工作。下面我们将详细介绍...
### KornShell脚本入门知识点详解 #### 一、Shell概念及作用 - **定义**:Shell是连接用户与操作系统的桥梁,使用户能够通过命令行界面与系统内核进行交互。 - **重要性**:在类UNIX系统(如IBM AIX)中,Shell充当...