从别人的脚本学shell(1)

本文介绍了Shell脚本中字符串操作的技巧,包括使用${}

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

拿到一个别人的示例脚本,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的意思

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值