Linux中bashshell的一些知识

  

数据流重导向

重导向redirect:就是将当前的所得数据输出到其他地方;

三种输出输入的状况,分别是:

—标准输入stdin:代码为0;使用<或<<

—标准输出stdout:代码为1;使用方式为1>或>>;

—标准输出stderror:代码为2;使用的方式为2>或2>>;

Find / -name file 1> list_right 2>list_error;

同时写入同一个档案

find / -name file 1>list 2>&1(推荐使用这个,后面这个命令使用会使错误信息输出不全);或find / -name file >list 2>list

(cat主要有三大功能:

1.一次显示整个文件。$ cat filename

2.从键盘创建一个文件。$ cat > filename  

   只能创建新文件,不能编辑已有文件.

3.将几个文件合并为一个文件: $cat file1 file2 > file

参数:

-n 或 --number 由 1 开始对所有输出的行数编号

-b 或 --number-nonblank 和 -n 相似,只不过对于空白行不编号

-s 或 --squeeze-blank 当遇到有连续两行以上的空白行,就代换为一行的空白行

-v 或 --show-nonprinting

双向重导向tee

tee :将数据流同时输出到屏幕和文件;

tee –a
file

-a :以累加的方式,将数据加入file中;

命令执行的判断依据:;&& ||

Command1;command2
利用分号“;”来分隔,这个分号的意思,代表不论command1执行结果为何,command都会被执行;

Command1
&&command2 如果command1正确才执行command2;

Command1
||command2 如果command1错误才执行command2;

管道命令(pipe

切记:管道命令“|”只能处理通过前面一个命令传来的正确信息,也就是标准输出(STDOUT)的信息,对于标准错误,没有处理能力;

 
   

Linux中bashshell的一些知识

选取命令cut 和grep

选取命令:就是将一段数据分析后,取出我们想要的部分(cut),或者是,通过分析关键字,取得我们想要的行(grep)。选取信息通常是针对“逐行”分析得到的,而不是针对整个信息分析的。

Cut :就是切,这个命令可以将一段信息的某段切出来,消息以行为单位;

Cut –d “分隔字符” –f
fields

Cut –c 字符范围

参数说明:

-d:后面接分隔符,预设是空格符,与-f一起使用;

-c:以字符为单位取出固定的字符范围;-f:根据-d分隔符一段消息分为数段,用-f是取出第几段的意思;

Grep 分析一行信息,若其中有需要的信息,就将这一行信息显示出来;

Grep [-acinv] ‘搜索字符串’ filename

-a 将二进制文件以文本的方式搜索数据;

-c 计算找到‘搜索字符串‘的次数;-i:忽略大小写的不同,所有大小写视为相同;-n:顺便输出行号;-v:反向选择,即显示没有‘搜索字符串的那一行’

排序命令:sort  wc uniq

Sort [-fbMnrtuk]
[file or stdin]

参数说明:-f:忽略大小写的差异,-b:忽略最前面的空格字符部分;-M:以月份的名字赖排序;-n:使用纯数字排序(默认使用文字类型来排序);-r:反向排序;-t:分隔符,默认是tab;-u:就是uniq,相同数据,只列出一次显示;-k:按那个字段(field)来排序;

Uniq [-ic]

-i 忽略大小写;-c 进行计数;

wc [-lwm]

-l 仅显示多少行;-w 仅显示有多少字;-m 多少字符;

字符转换命令

字符转化命令tr,col,join,paste,expand;

tr 可以用来删除一段信息当中的文字,或者是进行文字信息的替换;tr [-ds] str …

参数:-d :删除信息当中的str这个字符串;-s :取代掉重复的字符;

 
  Linux中bashshell的一些知识
上一篇:【原创】关于java对象需要重写equals方法,hashcode方法,toString方法 ,compareto()方法的说明


下一篇:Java—API/Obiect类的equals toString方法/String类/StringBuffer类/正则表达式