linux shell

1、"2>&1"含义

例如:command>out.file 2>&1 &

0:表示键盘输入

1:表示屏幕输出
2:表示错误输出

command>out.file是将command的输出重定向到out.file文件,即输出内容不打印到屏幕上,而是输出到out.file文件中。2>&1是将标准出错重定向到标准输出,这里的标准输出已经重定向到了out.file文件,即将标准出错也输出到out.file文件中。最后一个&是让该命令在后台执行。

 

试想2>1代表什么,2与>结合代表错误重定向,而1则代表错误重定向到一个文件1,而不代表标准输出;换成2>&1,&与1结合就代表标准输出了,就变成错误重定向到标准输出。
你可以用:
(1) ls 2>1测试一下,不会报没有2文件的错误,但会输出一个空的文件1;
(2) ls xxx 2>1测试,没有xxx这个文件的错误输出到了1中;
(3) ls xxx 2>&1测试,不会生成1这个文件了,不过错误跑到标准输出了;
(4) ls xxx >out.txt 2>&1, 实际上可换成 ls xxx 1>out.txt 2>&1;重定向符号>默认是1,错误和输出都传到out.txt了。


为何2>&1要写在后面?
command > file 2>&1
首先是command > file将标准输出重定向到file中, 2>&1 是标准错误拷贝了标准输出的行为,也就是同样被重定向到file中,最终结果就是标准输出和错误都被重定向到file中。
command 2>&1 >file
2>&1 标准错误拷贝了标准输出的行为,但此时标准输出还是在终端。>file 后输出才被重定向到file,但标准错误仍然保持在终端。

 

2、shell EOF

Shell中通常将EOF与 << 结合使用,表示后续的输入作为子命令或子Shell的输入,直到遇到EOF为止,再返回到主调Shell。如下:
sqlplus $USERID @$OUT_FILE << EOF
    commond内容
EOF

可以把EOF替换成其他东西

意思是把内容当作标准输入传给程序这里再简要回顾一下<<的用法。当shell看到<<的时候,它就会知道下一个词是一个分界符。在该分界符以后的内容都被当作输入,直到shell又看到该分界符(位于单独的一行)。

这个分界符可以是你所定义的任何字符串。

 

3、quoting

常用的 quoting 有如下三种方法:

* hard quote:' ' (单引号),所有meta均被关闭,除了自己,只能配对。
* soft quote:" " (双引号),大部份meta都会被关闭,但保留$、`反引号、\反斜杠,自己只能配对。
* escape:\ (反斜线),只有紧接在 \之后的单一meta才被关闭。

 

'(单引号)组合的优先级比\高 echo ‘Hatter\‘s tea party 输出Hatter\s tea party

 

4、命令替换

a. 反引号`
反引号用于设置系统命令的输出到变量,将其看作一条命令执行它,并保存结果。
echo `date`
Sat Nov 20 21:40:47 CST 2010

 

b. $()
count=$(echo $1 | sed 's/^-//') #命令替换,相当于``反引号,用于赋值
` ` 需要额外的逃脱符( \` )处理,而 $( ) 則比较直观。
command1 `command2 `command3` `
原本的意图是要在 command2 `command3` 先將 command3 提换出來给 command 2 处理,然后再将结果传递給 command1 `command2 ...` 來处理。
然而,真正的结果在命令行中却是分成了 `command2 ` 与 `` 兩段。
正确的输入应该:command1 `command2 \`command3\` `
要不然,换成 $( ) 就没有问题了:
command1 $(command2 $(command3))

 

5、wildcard

wildcard匹配符号,在Command Line的位置里, wildcard只作用于argument的path上.

a  *  匹配任意
b  ? 匹配单个字符
c  [] 匹配字符集 :[a-zA-Z] [!a-z],前面加!全否定;用[\!]匹配!
d  {string1,string2...} 匹配字符串  a{ss,dd,ee}m 匹配 assm addm aeem  {2..5}  2 3 4 5


tips:
a. *.txt 并不能匹配 .txt 但可匹配 1.txt 这样的路径名称.
b. 1*txt 及 1?txt 均可匹配 1.txt这样的路径名称

 

6、shell 语法(if后面需要空格)

#!/bin/bash 

function myfun()
{
    echo "myfun"
    return 0
}

#判断标准输入中是否包含hello
#if后面接命令
if grep "hello" >/dev/null 2>&1 ;then
    echo "include hello"
else
    echo "don't include hello"
fi

#if后面接函数调用
if myfun ;then
    echo "myfun success"
else
    echo "myfun error"
fi

#if后面接test语句 
read T
if [ "$T" -lt "10" ] ;then 
    echo " T < 10"
elif [ "$T" -le "20" -a "$T" -ge "10" ] ;then 
    #[]中应该使用-a -o 而不是使用&& ||
    echo " T >= 10 && T <= 20 "
else 
    echo " T > 20"
fi

 7、逻辑表达式

[ -f "somefile" ] :判断是否是一个文件
[ -x "/bin/ls" ] :判断/bin/ls是否存在并有可执行权限
[ -n "$var" ] :判断$var变量是否有值
[ "$a" = "$b" ] :判断$a和$b是否相等
-r file     用户可读为真
-w file     用户可写为真
-x file     用户可执行为真
-f file     文件为正规文件为真
-d file     文件为目录为真
-c file     文件为字符特殊文件为真
-b file     文件为块特殊文件为真
-s file     文件大小非0时为真
-t file     当文件描述符(默认为1)指定的设备为终端时为真

含条件选择的shell脚本 对于不含变量的任务简单shell脚本一般能胜任。但在执行一些决策任务时,就需要包含if/then的条件判断了。shell脚本编程支持此类运算,包括比较运算、判断文件是否存在等。
基本的if条件命令选项有: - eq —比较两个参数是否相等(例如,if [ 2 –eq 5 ])
-ne —比较两个参数是否不相等
-lt —参数1是否小于参数2
-le —参数1是否小于等于参数2
-gt —参数1是否大于参数2
-ge —参数1是否大于等于参数2
-f — 检查某文件是否存在(例如,if [ -f "filename" ])
-d — 检查目录是否存在

 

if 条件判断中有多个条件
#!/bin/bash
score=$1
if [ $score = 5 ]||[ $score = 3 ];then
    echo right
else
    echo wrong
fi

#!/bin/bash
score=$1
if [ $score -gt 15 ]||([ $score -lt 8 ]&&[ $score -ne 5 ]);then
    echo right
else
    echo wrong
fi


-------------------------------------------------------

或:
#!/bin/bash
count="$1"
if [ $count -gt 15 -o $count -lt 5 ];then
   echo right
fi

且:
#!/bin/bash
count="$1"
if [ $count -gt 5 -a $count -lt 15 ];then
   echo right
fi
-------------------------------------------------------

记住必须加两个中括号
score=$1
if [[ $score -gt 15 || $score -lt 8 && $score -ne 5 ]];then
    echo right
else
    echo wrong
fi

  

 

8、循环自增(if后面需要空格)

for info in $infos
do
        let i++
        if [ $i -eq 1 ];then
                value+="`jstack $info | grep BLOCKED -c` $info $HOSTNAME "
        elif [ $i -eq 2 ];then
                value+=$info
                value+="\n"
                i=0;
        fi
done

#循环参数
ARGS=($*)
for ((i=0; i<${#ARGS[@]}; i++)); do
	echo ${ARGS[$i]}
done

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值