首页 > 代码库 > linux shell中的比较符号与特殊符号介绍

linux shell中的比较符号与特殊符号介绍

shell字符串比较、判断是否为数字 

二元比较操作符,比较变量或者比较数字。注意数字与字符串的区别。 

整数比较 

-eq 等于,如:if [ "$a" -eq "$b" ] 
-ne 
不等于,如:if [ "$a" -ne "$b" ] 
-gt 大于,如:if [ "$a" -gt "$b" ] 
-ge 大于等于,如:if [ 
"$a" -ge "$b" ] 
-lt 小于,如:if [ "$a" -lt "$b" ] 
-le 小于等于,如:if [ "$a" -le 
"$b" ] 
< 小于(需要双括号),如:(("$a" < "$b")) 
<= 小于等于(需要双括号),如:(("$a" 
<= "$b")) 
> 大于(需要双括号),如:(("$a" > "$b")) 
>= 
大于等于(需要双括号),如:(("$a" >= "$b")) 

字符串比较 

= 
等于,如:if [ "$a" = "$b" ] 
== 等于,如:if [ "$a" == "$b" ],与=等价 
注意:==的功能在[[]]和[]中的行为是不同的,如下: 

1 [[ $a == z* ]] # 
如果$a以"z"开头(模式匹配)那么将为true 
2 [[ $a == "z*" ]] # 如果$a等于z*(字符匹配),那么结果为true 
3 
4 [ $a == z* ] # File globbing 和word splitting将会发生 
5 [ "$a" == "z*" ] # 
如果$a等于z*(字符匹配),那么结果为true 

一点解释,关于File 
globbing是一种关于文件的速记法,比如"*.c"就是,再如~也是. 
但是file 
globbing并不是严格的正则表达式,虽然绝大多数情况下结构比较像. 

!= 不等于,如:if [ "$a" != "$b" ] 
这个操作符将在[[]]结构中使用模式匹配. 
< 小于,在ASCII字母顺序下.如: 
if [[ "$a" < "$b" ]] 
if [ "$a" \< "$b" ] 
注意:在[]结构中"<"需要被转义. 
> 大于,在ASCII字母顺序下.如: 
if [[ "$a" > "$b" ]] 
if [ "$a" \> "$b" ] 
注意:在[]结构中">"需要被转义. 
具体参考Example 26-11来查看这个操作符应用的例子. 
-z 字符串为"null".就是长度为0. 
-n 字符串不为"null" 

注意: 

使用-n在[]结构中测试必须要用""把变量引起来.使用一个未被""的字符串来使用! -z 
或者就是未用""引用的字符串本身,放到[]结构中。虽然一般情况下可 
以工作,但这是不安全的.习惯于使用""来测试字符串是一种好习惯. 

awk ‘{print $2}‘ class.txt | grep ‘^[0-9.]‘ > res 

SHELL下的数字比较及计算 

比较: 

方法一: if [ ${A} -lt 
${B} ]; then ... 
这是最基本的比较方法,使用lt(小于),gt(大于),le(小于等于),ge(大于等于),优点:还没发现;缺点:只能比较整数,使用lt,gt等不直观 

方法二: if ((${A} < ${B})) then ... 
这是CShell风格比较,优点:不用使用lt,gt等难记的字符串;缺点:还是只能比较整数 

方法三: if (echo ${A} ${B} 
| awk ‘!($1>$2){exit 1}‘) then ... 
这是使用awk比较,优点:可以比较小数;缺点:表达式太复杂,难记 

方法四: if (echo ${A} - ${B} | bc -q | grep -q "^-"); then ... 
这是使用bc计算比较,优点:可以比较小数;缺点:表达式更复杂,难记 

计算: 
方法一:typeset C=$(expr ${A} 
+ ${B}); 
SHELL中的基本工具,优点:方便检测变量是否为数字;缺点:只能计算整数,且只能计算加减法,不能计算乘除法 

方法二:let "C=${A}+${B}"; 或 let "C=A+B" 
内嵌命令计算,优点:能计算乘除法及位运算等;缺点:只能计算整数 

方法三:typeset C=$((A+B)) 
CShell风格的计算,优点:能计算乘除法及位运算等,简介,编写方便;缺点:不能计算小数 

方法四:typeset C=${echo ${A} ${B} | awk ‘{print $1+$2}‘) 
使用awk计算,优点:能计算小数,可以实现多种计算方式,计算灵活;缺点:表达式太复杂 

方法五:typeset C=${echo ${A} 
+ ${B} | bc -q) 
使用awk计算,优点:能计算小数,计算方式比awk还多,计算灵活;缺点:表达式太复杂,小数点后面的位数必须使用scale=N来设置,否则可能会将结果截断为整数 


特殊字符 

符号 使用 
; 
一般情况我们输出完一个命令需要按一个回车,如果你想在一行执行多个命令,中间可以用;号分割 cd /home ; ls 
* 表示任意字符(正则) 
? 任一个字符 
[abc] 列表项之一 
[^abc] 对于列表取非 也可以使用范围 [a-z] [0-9] [A-Z](所有字符和数字) 
{} 循环列表时用 touch_{1,2,3}时就会建立touch_1,touch_2,touch_3循环出这三个文件,也会用 echo ${ab}c 
~ home目录cd ~ (普通通话进入的是/home目录下用户自己的家目录) 
$ 提取变量值 
`` $() 命令替换touch 
`date +%F_\`date +%T\`` touch $(date +%F_$(date +%T)) 
$[] 整数计算 echo $[2+3] - 
* / % 浮点数用 echo "scale=3; 10/3" | bc -l (bc用于计算的) 
\ 转义后面的字符串 echo \\ 输出\ 
转义特殊字符,为防止被SHELL解释bash中的特殊字符 
"" ‘‘ 带空格串 将空格视为串的一部分 echo "abc xyz" echo ‘abc 
xyz‘ 
`` 命令替换 取命令的执行结果 
$() 同上,但它弥补了``的嵌套缺陷 
@ 无特殊含义 
# 
注释(一般编程都需要加注释,让其他团队队员对自己写的程序功能了解) 
$ 变量取值 
$() 命令替换 
${} 变量名的范围 
% 
杀后台经常jobs号,取模运算(大家对取模应该并不陌生) 
^ 取非 和 !雷同 
& 用进程后台处理, &&用于逻辑与 
* 匹配任意字符串;计算乘法 
() 子进程执行 
- 减号,区间,cd - 回到上层目录,杀掉当前jobs 

_ 
(下划线)无特殊含义 
+ 加号; 杀掉当前jobs(进程) 
= 赋值 
| 管道,|| 逻辑或 
\ 转义 
当一些特殊符号如$是一个变量需要转义才不被bash解析 
{} 命令列表 {ls;cd /;} 
[] 字符通配符,[]也是用于测试命令 
: 
空命令 真值 
; 命令结束符 
"" 软引 ‘‘ 硬引 
< 输入重定向 
> 输出重定向 
>& 
合并2和1输出 
, 枚举分隔符 
. 当前目录 
/ 目录分隔符 
? 单个字符 
回车 命令执行


本文出自 “落日余晖” 博客,请务必保留此出处http://whluwit.blog.51cto.com/2306565/1438150