从别人的脚本学shell(1)

前端之家收集整理的这篇文章主要介绍了从别人的脚本学shell(1)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

拿到一个别人的示例脚本,700多行,看的各种晕,慢慢学吧,一点点来。

字符串操作相关

示例1

Platform=$(echo ${uname_a%% *}|tr a-z A-Z);

开始扫盲:

盲点1:%% *

介绍下Shell中的${}、##和%%使用范例,本文给出了不同情况下得到的结果。

假设定义了一个变量为:
代码如下:

file=/dir1/dir2/dir3/my.file.txt

可以用${ }分别替换得到不同的值:
${file#*/}:删掉第一个 / 及其左边的字符串:/ dir1/dir2/dir3/my.file.txt
${file##*/}:删掉最后一个 / 及其左边的字符串:/dir1/dir2/dir3/ my.file.txt
${file#*.}:删掉第一个 . 及其左边的字符串:file.txt(/dir1/dir2/dir3/my. file.txt)
${file##*.}:删掉最后一个 . 及其左边的字符串:txt(/dir1/dir2/dir3/my.file. txt)
${file%/*}:删掉最后一个 / 及其右边的字符串:/dir1/dir2/dir3(/dir1/dir2/dir3 /my.file.txt)
${file%%/*}:删掉第一个 / 及其右边的字符串:(空值) ( /dir1/dir2/dir3/my.file.txt)
${file%.*}:删掉最后一个 . 及其右边的字符串:/dir1/dir2/dir3/my.file (/dir1/dir2/dir3/my.file .txt)
${file%%.*}:删掉第一个 . 及其右边的字符串:/dir1/dir2/dir3/my (/dir1/dir2/dir3/my.file.txt)
记忆的方法为:

  • “#” 是 去掉左边(键盘上#在 $ 的左边);
  • “%”是去掉右边(键盘上% 在$ 的右边);
  • 单一符号是最小匹配;两个符号是最大匹配,(怎么删的多怎么来)

${file:0:5}提取最左边的 5 个字节:/dir1
${file:5:5}提取第 5 个字节右边的连续5个字节:/dir2
也可以对变量值里的字符串作替换:
${file/dir/path}:将第一个dir 替换为path:/path1/dir2/dir3/my.file.txt
${file//dir/path}:将全部dir 替换为 path:/path1/path2/path3/my.file.txt

[root@bogon tmp]# uname -a
Linux bogon 2.6.32-358.el6.x86_64 #1 SMP Fri Feb 22 00:31:26 UTC 2013 x86_64 x86_64 x86_64 GNU/Linux

所以 ${uname_a%% *}是去掉第一个空格右边的所有字符,得到结果是Linux。

盲点2:tr a-z A-Z

  tr命令可以对来自标准输入的字符进行替换、压缩和删除。它可以将一组字符变成另一组字符,经常用来编写优美的单行命令,作用很强大。
  语法:
tr(选项)(参数)
  选项:

  • -c或 - -complerment:取代所有不属于第一字符集的字符;
  • -d或- -delete:删除所有属于第一字符集的字符;
  • -s或- -squeeze-repeats:把连续重复的字符以单独一个字符表示;
  • -t或- -truncate-set1:先删除第一字符集较第二字符集多出的字符。

      参数:

  • 字符集1:指定要转换或删除的原字符集。当执行转换操作时,必须使用参数“字符集2”指定转换的目标字符集。但执行删除操作时,不需要参数“字符集2”;

  • 字符集2:指定要转换成的目标字符集。

  示例:
将输入字符由大写转换为小写:

echo "HELLO WORLD" | tr 'A-Z' 'a-z' 
hello world

‘A-Z’ 和 ‘a-z’都是集合,集合是可以自己制定的,例如:’ABD-}’、’bB.,’、’a-de-h’、’a-c0-9’都属于集合,集合里可以使用’\n’、’\t’,可以可以使用其他ASCII字符。

echo "hello 123 world 456" | tr -d '0-9' 
hello world

将制表符转换为空格:

cat text | tr '\t' ' '

字符集补集,从输入文本中将不在补集中的所有字符删除

echo aa.,a 1 b#$bb 2 c*/cc 3 ddd 4 | tr -d -c '0-9 \n' 
  1 2 3 4

  此例中,补集中包含了数字0~9、空格和换行符\n,所以没有被删除,其他字符全部被删除了。
用tr压缩字符,可以压缩输入中重复的字符:

this is a text line.

巧妙使用tr做数字相加操作:

echo 1 2 3 4 5 6 7 8 9 | xargs -n1 | echo $[ $(tr '\n' '+') 0 ]

删除Windows文件“造成”的’^M’字符:

cat file | tr -s "\r" "\n" > new_file

cat file | tr -d "\r" > new_file

这里的tr就是做了一个大小写切换

所以最后得到的Platform是LINUX。

示例2 if [ -x “/opsw/bin/rosh” ]

### 盲点1: -x的含义
Linux_shell条件判断if中的-a到-z的意思
[ -a FILE ] 如果 FILE 存在则为真。
[ -b FILE ] 如果 FILE 存在且是一个块特殊文件则为真。
[ -c FILE ] 如果 FILE 存在且是一个字特殊文件则为真。
[ -d FILE ] 如果 FILE 存在且是一个目录则为真。
[ -e FILE ] 如果 FILE 存在则为真。
[ -f FILE ] 如果 FILE 存在且是一个普通文件则为真。
[ -g FILE ] 如果 FILE 存在且已经设置了SGID则为真。 [ -h FILE ] 如果 FILE 存在且是一个符号连接则为真。
[ -k FILE ] 如果 FILE 存在且已经设置了粘制位则为真。
[ -p FILE ] 如果 FILE 存在且是一个名字管道(F如果O)则为真。
[ -r FILE ] 如果 FILE 存在且是可读的则为真。
[ -s FILE ] 如果 FILE 存在且大小不为0则为真。
[ -t FD ] 如果文件描述符 FD 打开且指向一个终端则为真。
[ -u FILE ] 如果 FILE 存在且设置了SUID (set user ID)则为真。
[ -w FILE ] 如果 FILE 如果 FILE 存在且是可写的则为真。
[ -x FILE ] 如果 FILE 存在且是可执行的则为真。
[ -O FILE ] 如果 FILE 存在且属有效用户ID则为真。
[ -G FILE ] 如果 FILE 存在且属有效用户组则为真。
[ -L FILE ] 如果 FILE 存在且是一个符号连接则为真。
[ -N FILE ] 如果 FILE 存在 and has been mod如果ied since it was last read则为真。
[ -S FILE ] 如果 FILE 存在且是一个套接字则为真。
[ FILE1 -nt FILE2 ] 如果 FILE1 has been changed more recently than FILE2,or 如果 FILE1 exists and FILE2 does not则为真。
[ FILE1 -ot FILE2 ] 如果 FILE1 比 FILE2 要老,或者 FILE2 存在且 FILE1 不存在则为真。
[ FILE1 -ef FILE2 ] 如果 FILE1 和 FILE2 指向相同的设备和节点号则为真。
[ -o OPTIONNAME ] 如果 shell选项 “OPTIONNAME” 开启则为真。
[ -z STRING ] “STRING” 的长度为零则为真。
[ -n STRING ] or [ STRING ] “STRING” 的长度为非零 non-zero则为真。
[ STRING1 == STRING2 ] 如果2个字符串相同。 “=” may be used instead of “==” for strict POSIX compliance则为真。
[ STRING1 != STRING2 ] 如果字符串不相等则为真。
[ STRING1 < STRING2 ] 如果 “STRING1” sorts before “STRING2” lexicographically in the current locale则为真。
[ STRING1 > STRING2 ] 如果 “STRING1” sorts after “STRING2” lexicographically in the current locale则为真。
[ ARG1 OP ARG2 ] “OP” is one of -eq,-ne,-lt,-le,-gt or -ge. These arithmetic binary operators return true if “ARG1” is equal to,not equal to,less than,less than or equal to,greater than,or greater than or equal to “ARG2”,respectively. “ARG1” and “ARG2” are integers.

=====================================================================

基本上和其他脚本语言一样。没有太大区别。不过值得注意的是。[]里面的条件判断

1、字符串判断

str1 = str2      当两个串有相同内容、长度时为真
str1 != str2      当串str1和str2不等时为真
-n str1        当串的长度大于0时为真(串非空)
-z str1        当串的长度为0时为真(空串)
str1         当串str1为非空时为真

2、数字的判断

int1 -eq int2    两数相等为真
int1 -ne int2    两数不等为真
int1 -gt int2    int1大于int2为真
int1 -ge int2    int1大于等于int2为真
int1 -lt int2    int1小于int2为真
int1 -le int2    int1小于等于int2为真

3、文件的判断

-r file     用户可读为真
-w file     用户可写为真
-x file     用户可执行为真
-f file     文件为正规文件为真
-d file     文件为目录为真
-c file     文件为字符特殊文件为真
-b file     文件为块特殊文件为真
-s file     文件大小非0时为真
-t file     当文件描述符(默认为1)指定的设备为终端时为真

4、复杂逻辑判断

-a         与
-o        或
!        非

结尾

语法虽然简单,但是在SHELL里使用的时候,他的功能变得强大了。

参考:Linux shell条件判断if中的-a到-z的意思

猜你在找的Bash相关文章