微信开发中 ACCESS TOKEN 过期失效的解决方案详解
582
2022-09-25
bash学习笔记
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(只替换第一个找到的内容),最后一个特殊符号也不能省掉。 在替换表达式中可以使用 这样的特殊参数来替代前面正则表达式中匹配的部分内容,例如:sed -n 's/.*\(movie_Play.asp?Id=[0-9]\+\).*/这里最后一个p把内容显示到屏幕上 进行多次处理,以简化表达式:grep "Id=[0-9]\+.*img" movie_list.htm | sed -n 's/.*\(movie_Play.asp?Id=[0-9]\+\).*/ 还有awk cut 等命令可以完成相似的功能,参见/etc 下的相应代码 以及 info awk , info cut 3、查看命令的位置,察看文件的类型 which which 察看命令文件的位置,这个是一个单独的文件 type type 察看命令文件的位置,这个是bash内置命令 file /dev/null 察看文件的格式信息 4、在您的家目录里的.bash_history里记录前一次登入以前所执行的命令。 而这一次登入所执行的指令都被放在内存中。注销后该指令记忆才会记录到.bash_history当中。 假如登录到别人的机子想看看他用过的指令......... 5、history配合"!"使用。 history !HISTORY_NUMBER6、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,
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]\+\).*/这里最后一个p把内容显示到屏幕上
进行多次处理,以简化表达式:grep "Id=[0-9]\+.*img" movie_list.htm | sed -n 's/.*\(movie_Play.asp?Id=[0-9]\+\).*/
还有awk cut 等命令可以完成相似的功能,参见/etc 下的相应代码 以及 info awk , info cut
3、查看命令的位置,察看文件的类型
which which 察看命令文件的位置,这个是一个单独的文件
type type 察看命令文件的位置,这个是bash内置命令
file /dev/null 察看文件的格式信息
4、在您的家目录里的.bash_history里记录前一次登入以前所执行的命令。 而这一次登入所执行的指令都被放在内存中。注销后该指令记忆才会记录到.bash_history当中。 假如登录到别人的机子想看看他用过的指令.........
5、history配合"!"使用。 history !HISTORY_NUMBER6、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
12. How to obtain the program option paramters.
#!/bin/bash#getoptsALL=falseHELP=falseFILE=falseVERBOSE=falsewhile 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" ; esacdone
输入./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 expected
4) There is bank right behind [ and before ], they are necessary.
14. Simple commands.
stty erase
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]\+\).*/这里最后一个p把内容显示到屏幕上
进行多次处理,以简化表达式:grep "Id=[0-9]\+.*img" movie_list.htm | sed -n 's/.*\(movie_Play.asp?Id=[0-9]\+\).*/
还有awk cut 等命令可以完成相似的功能,参见/etc 下的相应代码 以及 info awk , info cut
3、查看命令的位置,察看文件的类型
which which 察看命令文件的位置,这个是一个单独的文件
type type 察看命令文件的位置,这个是bash内置命令
file /dev/null 察看文件的格式信息
4、在您的家目录里的.bash_history里记录前一次登入以前所执行的命令。 而这一次登入所执行的指令都被放在内存中。注销后该指令记忆才会记录到.bash_history当中。 假如登录到别人的机子想看看他用过的指令.........
5、history配合"!"使用。 history !HISTORY_NUMBER6、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
12. How to obtain the program option paramters.
#!/bin/bash#getoptsALL=falseHELP=falseFILE=falseVERBOSE=falsewhile 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" ; esacdone
输入./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 expected
4) There is bank right behind [ and before ], they are necessary.
14. Simple commands.
stty erase
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]\+\).*/这里最后一个p把内容显示到屏幕上
进行多次处理,以简化表达式:grep "Id=[0-9]\+.*img" movie_list.htm | sed -n 's/.*\(movie_Play.asp?Id=[0-9]\+\).*/
还有awk cut 等命令可以完成相似的功能,参见/etc 下的相应代码 以及 info awk , info cut
3、查看命令的位置,察看文件的类型
which which 察看命令文件的位置,这个是一个单独的文件
type type 察看命令文件的位置,这个是bash内置命令
file /dev/null 察看文件的格式信息
4、在您的家目录里的.bash_history里记录前一次登入以前所执行的命令。 而这一次登入所执行的指令都被放在内存中。注销后该指令记忆才会记录到.bash_history当中。 假如登录到别人的机子想看看他用过的指令.........
5、history配合"!"使用。 history !HISTORY_NUMBER6、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
12. How to obtain the program option paramters.
#!/bin/bash#getoptsALL=falseHELP=falseFILE=falseVERBOSE=falsewhile 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" ; esacdone
输入./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 expected
4) There is bank right behind [ and before ], they are necessary.
14. Simple commands.
stty erase
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]\+\).*/这里最后一个p把内容显示到屏幕上
进行多次处理,以简化表达式:grep "Id=[0-9]\+.*img" movie_list.htm | sed -n 's/.*\(movie_Play.asp?Id=[0-9]\+\).*/
还有awk cut 等命令可以完成相似的功能,参见/etc 下的相应代码 以及 info awk , info cut
3、查看命令的位置,察看文件的类型
which which 察看命令文件的位置,这个是一个单独的文件
type type 察看命令文件的位置,这个是bash内置命令
file /dev/null 察看文件的格式信息
4、在您的家目录里的.bash_history里记录前一次登入以前所执行的命令。 而这一次登入所执行的指令都被放在内存中。注销后该指令记忆才会记录到.bash_history当中。 假如登录到别人的机子想看看他用过的指令.........
5、history配合"!"使用。 history !HISTORY_NUMBER6、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
12. How to obtain the program option paramters.
#!/bin/bash#getoptsALL=falseHELP=falseFILE=falseVERBOSE=falsewhile 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" ; esacdone
输入./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 expected
4) There is bank right behind [ and before ], they are necessary.
14. Simple commands.
stty erase
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~