linux shell比较命令

1 比较运算

num1-eq num2 等于 [ 3 -eq $mynum ]
num1-ne num2 不等于 [ 3 -ne $mynum ]
num1-lt num2 小于 [ 3 -lt $mynum ]
num1-le num2 小于或等于 [ 3 -le $mynum ]
num1-gt num2 大于 [ 3 -gt $mynum ]
num1-ge num2 大于或等于 [ 3 -ge $mynum ]。
filename1-nt filename2 如果 filename1比 filename2新,则为真 [ /tmp/install/etc/services -nt /etc/services ]
filename1-ot filename2 如果 filename1比 filename2旧,则为真 [ /boot/bzImage -ot arch/i386/boot/bzImage ]
字符串比较运算符 (请注意引号的使用,这是防止空格扰乱代码的好方法)
-z string 如果 string长度为零,则为真 [ -z "$myvar" ]
-n string 如果 string长度非零,则为真 [ -n "$myvar" ]
string1= string2 如果 string1与 string2相同,则为真 [ "$myvar" = "one two three" ]
string1!= string2 如果 string1与 string2不同,则为真 [ "$myvar" != "one two three" ]
算术比较运算符。

文件比较运算符-e filename      
如果 filename存在,则为真       [ -e /var/log/syslog ]-d filename       
如果 filename为目录,则为真      [ -d /tmp/mydir ]-f filename    
如果 filename为常规文件,则为真    [ -f /usr/bin/grep ]-L filename         
如果 filename为符号链接,则为真    [ -L /usr/bin/grep ]-r filename         
如果 filename可读,则为真       [ -r /var/log/syslog ]-w filename       
如果 filename可写,则为真       [ -w /var/mytmp.txt ]-x filename        
如果 filename可执行,则为真      [ -L /usr/bin/grep ]filename1-nt filename2      
如果 filename1比 filename2新,则为真    [ /tmp/install/etc/services -nt /etc/services ]filename1-ot filename2   
如果 filename1比 filename2旧,则为真    [ /boot/bzImage -ot arch/i386
/boot/bzImage ]字符串比较运算符 (请注意引号的使用,这是防止空格扰乱代码的好方法)
-z string 如果 string长度为零,则为真 [ -z "$myvar" ]-n string 如果 string长度非零,则为真 [ -n "$myvar" ]
string1= string2 如果 string1与 string2相同,则为真 [ "$myvar" = "one two three"]
string1!= string2 如果 string1与 string2不同,则为真 [ "$myvar" != "one two three" ]
算术比较运算符num1-eq num2 等于 [ 3 -eq $mynum ]
num1-ne num2 不等于 [ 3 -ne $mynum ]num1-lt num2 小于 [ 3 -lt $mynum ]
num1-le num2 小于或等于 [ 3 -le $mynum ]num1-gt num2 大于 [ 3 -gt $mynum ]
num1-ge num2 大于或等于 [ 3 -ge $mynum ]

2 awk

echo 'C20_660' | awk -F"_" '{print "" $1}' 
输出结果:C20

3 正则表达式

echo 'ACAA20_660' | sed 's/\([A-Z]\).*/\1/'
输出结果:A
echo 'XXACC20_660' | sed 's/[A-Z]\([0-9]\)/\1/'
输出结果:XXAC20_660

4 %,[@]用法

#表示掐头,% 表示去尾。
单个#或%的表示最小匹配,双个#或%表示最大匹配。
也就是说,当匹配有多种方案的时候,选择匹配最大长度还是最小长度。
如:workspace为/home/user/test.txt,则 %/* 最小匹配只会去除/test.txt;而 %%/* 会去除最长字串 /home/user/test.txt,即整个字串都被去除了。
因此,workspace=${workspace%/*} 就表示去除最后的文件名称,得到纯路径。

举例如下:

target_dir=$1
fnames=(`find $target_dir -name "*.wv1"`)
for fname in "${fnames[@]}"#遍历数组中的每个元素
do
  mv "$fname" "${fname%.wav}.nist"
  sndfile-convert "${fname%.wav}.nist" "$fname"
  if [ $? = 0 ]; then
    echo renamed $fname to nist and converted back to wav using sndfile-convert
  else
    mv "${fname%.wav}.nist" "$fname"
  fi
done

你可能感兴趣的:(Liunx,linux,服务器,java)