日期:2014-05-16  浏览次数:20704 次

[转]linux tee命令参数及用法详解---读取输入写入文件
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 字母间的任意字串。

  位址参数的个数 : 在指令中