1、搜索含有某个指令的脚本:find /etc 2>/dev/null |
xargs grep 'awk ' 2>/dev/null
- 说明:
- find /etc 查找/etc 目录下的所有文件,并显示文件名
- 2>/dev/null 把所有的错误信息,如权限错误,不能访问等等 重定向倒看不到的虚拟设备,只显示有用信息。(1代表“标准输出”,2代表“标准错误输出”)
- | 把前一个命令的输出以管道的方式传给后面的命令
- xargs 对输入的每一个参数,循环执行后面的命令
- grep 'awk' 在指定文件中查找字符串,这里的输入文件时xargs命令传过来的,每次去一个find输出的文件名
2、正则替换sed:
- sed -i 's/regExp1/replaceExp/g' file -i 代表直接替换文件中的内容 前面的s代表搜索替换,后面的g代表替换所有,三个 / 可以用任意字符替换,比如 sed 's@regExp1@replaceExp@g' file 或 sed 's#regExp1#replaceExp#g' file ,即使不要后面的g(只替换第一个找到的内容),最后一个特殊符号也不能省掉。
- 在替换表达式中可以使用 \1 这样的特殊参数来替代前面正则表达式中匹配的部分内容,例如:sed -n 's/.*\(movie_Play.asp?Id=[0-9]\+\).*/http:\/\/www.kankan.com\/\1/p' 这里最后一个p把内容显示到屏幕上
- 进行多次处理,以简化表达式:grep "Id=[0-9]\+.*img" movie_list.htm | sed -n 's/.*\(movie_Play.asp?Id=[0-9]\+\).*/http:\/\/www.kankan.com\/\1/p'
- 还有awk cut 等命令可以完成相似的功能,参见/etc 下的相应代码 以及 info awk , info cut
3、查看命令的位置,察看文件的类型
-
which which 察看命令文件的位置,这个是一个单独的文件
-
type type 察看命令文件的位置,这个是bash内置命令
-
file /dev/null 察看文件的格式信息
4、在您的家目录里的.bash_history里记录前一次登入以前所执行的命令。
而这一次登入所执行的指令都被放在内存中。注销后该指令记忆才会记录到.bash_history当中。
假如登录到别人的机子想看看他用过的指令.........
而这一次登入所执行的指令都被放在内存中。注销后该指令记忆才会记录到.bash_history当中。
假如登录到别人的机子想看看他用过的指令.........
5、history配合"!"使用。
history
!HISTORY_NUMBER
6、mkdir -p /dir1/dir2/dir3
Make the parent dirs if necessary.
7、echo -n "info"
Do not output the trailing newline
history
!HISTORY_NUMBER
6、mkdir -p /dir1/dir2/dir3
Make the parent dirs if necessary.
7、echo -n "info"
Do not output the trailing newline
8、比较语句可能是我在BASH脚本中用得最频繁的语句了,在进行分支判断,结果分析的时候往往都要借助于它。今天趁着空闲,对它作一个总结,以备忘。
比较语句其实就是判断表达式的真假。在BASH脚本中以0表示真,非0表示假,有一个有用的变量$?可以获取上次命令的返回结果。比如执行命令echo "test",再执行echo $?会返回0,因为echo语句的返回值总是正确的。
比较有多种方式,如简单的字符串比较,算术比较,文件是否为空比较等。所有这些比较都可以用test命令来完成,如test 2 -gt 1,就是判断2是否大于1。另外还可以用[...],``.``.``.``,((...))。其中((...))仅用于算术比较。
需要注意的是在括号与判断内容之间需要加空格,即[a]这样的判断语句是会报错的。而算术判断如果是在[...]和``.``.``.``中也不能简单地用>,<,=等来进行,而需要用-gt,-lt等,具体可以man test。比如要判断a是否大于b,[ a>b ]和[ a > b ]都是错误的,它们其实是执行了将a命令重定向到b文件的操作,要执行该判断,应该使用[ a -t b ]或者` a -t b `。
而如果是采用((...))的形式,则可以直接使用判断,即(( a>b ))来进行。
通常我们的判断往往跟随着后续操作,即判断为真,为假时的后续处理。这里可以用if...else语句,也可以采用简便的&&..||形式。比如我们判断a是否大于b,是则打印"a>b",否则打印"a<=b"。可以如下写相关脚本:
if [ a -gt b ]; then
echo "a>b"
else
echo "a<=b"
fi
或者简单地写为:
[ a -gt b ] && echo "a>b" || echo "a<=b"
其效果是一样的。
有时候我们不是进行简单的比较,而是要判断内容是否符合某正则表达式,通常可以采用echo...grep的方式来实现。比如我们要判断字符串a是否以“test"开头,可以写为:
if echo $a | grep "^test"; then
echo "matched"
else
echo “not matched"
fi
9、有两种形式的命令替换
- 例如:将当前工作目录的全路径名存放到变量 dir 中,输入以下命令行:
- $ dir =` pwd `
- 另一种形式是:$ ( 命令表 ) 。上面的命令行也可以改写为:
- $ dir =$ ( pwd )
10、How to kill all of the processes of an executable?
ps -A | grep evince | cut -d " " -f2 | xargs kill -9 2> /dev/null
11. Parameter handover.
The ksh paramerter comprises $order, for example, $0, $1. The $0 means the program itself or the function itself, just like the C++, so the $1 is the first parameter, $2 second...
There are other parameter information,
$# ----传递给程序的总的参数数目
$? ----上一个代码或者shell程序在shell中退出的情况,如果正常退出则返回0,反之为非0值。
$* ----传递给程序的所有参数组成的字符串。
$n ----表示第几个参数,$1 表示第一个参数,$2 表示第二个参数 ...
$0 ----当前程序的名称
$@----以"参数1" "参数2" ... 形式保存所有参数
$$ ----本程序的(进程ID号)PID
$! ----上一个命令的PID
$? ----上一个代码或者shell程序在shell中退出的情况,如果正常退出则返回0,反之为非0值。
$* ----传递给程序的所有参数组成的字符串。
$n ----表示第几个参数,$1 表示第一个参数,$2 表示第二个参数 ...
$0 ----当前程序的名称
$@----以"参数1" "参数2" ... 形式保存所有参数
$$ ----本程序的(进程ID号)PID
$! ----上一个命令的PID
12. How to obtain the program option paramters.
#!/bin/bash
#getopts
ALL=false
HELP=false
FILE=false
VERBOSE=false
while getopts ahfvc: OPTION #将ahfvc依次传给OPTION c后面的:表示-c时需传入参数
do
case ${OPTION} in
a)
ALL=true
echo "ALL IS ${ALL}"
;
h)
HELP=true
echo "HELP IS ${HELP}"
;
f)
FILE=true
echo "FILE IS ${FILE}"
;
v)
VERBOS=false
echo "VERBOSE IS ${VERBOSE}"
;
c)
c=${OPTARG}
echo "c value is $c"
;
\?)
echo "`basename $0` -[a h f v] -[c value] file"
;
esac
done
输入./getopts -a 输出:ALL IS true #执行case a模式的命令
输入./getopts -h 输出:HLEP IS true #执行case h模式的命令
输入./getopts -f 输出:FILE IS true #执行case f模式的命令
输入./getopts -v 输出:VERBOSE IS true #执行case v模式的命令
输入./getopts -c 提示错误:需要传入参数 #c后面有“:”所以需传参数
输入./getopts -c hello 输出:c value is hello #执行case c模式的命令
输入./getopts -b 输出:basename ./getopts -[a h f v] -[c value] file #其他情况
13. How to compare 2 string?
The sign = is used to compare the 2 stirngs while -eq is used to compare the 2 numbers.
比较两个字符串是否相等的办法是:if [ "$test"x = "test"x ]; then这里的关键有几点:1) 使用单个等号2) 注意到等号两边各有一个空格:这是unix shell的要求3) 注意到"$test"x最后的x,这是特意安排的,因为当$test为空的时候,上面的表达式就变成了x = testx,显然是不相等的。而如果没有这个x,表达式就会报错:[: =: unary operator expected4) There is bank right behind [ and before ], they are necessary.
14. Simple commands.
stty erase <BackSpace> ###use the backslash as the delete key.
PS1="
`/usr/ucb/whoami`@`uname -n`(KSH)[!]> " ###used to cumtomiz the command echo.
set -o vi ###set the edition mode as vi, you have the command history with that.
find . -name "test" -type f ! -newer source_test -exec cp source_test {} \; ###How to copy file when the destination file is newer file?
How to use the options parameters.
Please refer to the tutorial.
Ksh reference manual.
转载于:https://blog.51cto.com/robertleepeak/197483