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}‘