1..cmp
cmp命令是上边diff命令的一个简单版本. diff命令会报告两个文件的不同之处, 而cmp命令仅仅指出哪些位置有所不同, 不会显示不同之处的具体细节.就像diff命令那样, 如果两个文件相同的话, cmp将返回0作为退出状态码, 如果不同就返回1. 这样能用在shell脚本的测试结构中了.
2.basename 从文件名中去掉路径信息, 只打印出文件名
dirname 从带路径的文件名字符串中去掉文件名(basename), 只打印出路径信息.
3.a=/home/bozo/daily-journal.txt
echo "Basename of /home/bozo/daily-journal.txt = `basename $a`"
echo "Dirname of /home/bozo/daily-journal.txt = `dirname $a`"
4.#!/bin/sh将会调用默认的shell解释器, 在Linux机器上默认是/bin/bash.
5.#作为行的开头, 当命令解释器执行这个脚本的时候,会把它作为一个注释行. 当然, 在这之前, 这行语句已经完成了它的任务, 就是调用命令解释器.
6.如果Bash是你的默认shell, 那么脚本的开头也不用非得写上#!. 但是如果你使用不同的shell来开启一个脚本的话, 比如tcsh, 那么你就必须需要#!了.
7.查看系统支持哪些shell: cat /etc/shells -b
8.清空历史记录:history -c 允许历史记录的个数:history -w
9.;表示顺序执行,前面执行是否成功不影响后面的执行
10.&&前面命令执行成功后面执行,前面命令执行失败后面不执行
11.ent 系统变量 set 自己定义的变量和系统变量
12.$$ 进程号 $! 后台 $?上一条命令的执行结果的返回状态 $* 所有位置变量的值 $# 位置变量的个数 $0当前终端的进程名,当前执行的脚本名
13.shell中 -e 判断文件或目录是否存在
-d 判断是否是文件夹 存在切实文件夹为真
-f 判断文件是否存在,存在且是文件为真
-eq 相等 -lt 小于 -le 小于等于
-ne 不等 -gt 大于 -ge 大于等于
逻辑与 : 【1】&& 【2】 或者【1 -a 2 】
逻辑或 : [1] || [2] 或者 [1 -o 2]
14.流程控制:break :结束当前所在的循环结构
continue:结束当前所在循环结构本次循环,并开始下一次循环
exit: 结束脚本的执行,默认返回值是0,也可以制定结束脚本的返回值,格式:exit 数字
return:执行脚本或者函数时指定返回值,不会结束脚本,通常用来给函数设置返回值
15.设置正则表达式出现的次数;
\{n,m\} 限制正则表达式至少出现n次最多出现m次
\{n\} 正则表达式必须出现n次
\+ 至少出现一次
\? 最多出现一次
\{n,\} 至少出现n次
16.awk使用
Filename :大写,不用加$ ,有多少行就输出几次文件名 awk '{print FILENAME}' a.txt
$0 保存当前处理行的内容 awk '{print $0}' a.txt
NR awk当前处理行的行数 awk ‘{print NR,$0}' a.txt
FNR 当前处理行在文件中的行数 awk '{print FNR}’ a.txt
NF 用指定分隔符分割后每一行的列数
FS 存放分隔符的函数,可以自己指定,默认要读入第一行的时候才改变指定的分隔符,如: awk '{FS=“:”;print NF}‘