shell  脚本里的命令执行

1. 在bash中,$( )` `(反引号)都是用来作命令替换的。

  命令替换与变量替换差不多,都是用来重组命令行的,先完成引号里的命令行,然后将其结果替换出来,再重组成新的命令行。

$( )与``

在操作上,这两者都是达到相应的效果,但是建议使用$( ),理由如下:

``很容易与''搞混乱,尤其对初学者来说,而$( )比较直观。
最后,$( )的弊端是,并不是所有的类unix系统都支持这种方式,但反引号是肯定支持的。

关于命令嵌套:  

  $(ps -ef|grep `ps -ef|grep nginx |grep 'ottcache'|grep 'master process'|awk '{print $2}' ` |grep 'worker process'|awk '{print $2}')

里面的命令用 `` 反引号得出 pid, 再替换掉该位置, $()  执行另一个命令。

[root@CGSLV5_03 home]# echo today is $(date "+%Y-%m-%d")
today is 2019-08-14
[root@CGSLV5_03 home]# echo today is `date "+%Y-%m-%d"`
today is 2019-08-14
[root@CGSLV5_03 home]#
[root@localhost ~]#  echo Linux `echo Shell `echo today is `date "+%Y-%m-%d"```
Linux Shellecho today is 2017-11-07 #过多使用``会有问题
[root@localhost ~]# echo Linux `echo Shell $(echo today is $(date "+%Y-%m-%d"))`
Linux Shell today is 2017-11-07 ``和$()混合使用
[root@localhost ~]# echo Linux $(echo Shell $(echo today is $(date "+%Y-%m-%d")))
Linux Shell today is 2017-11-07 #多个$()同时使用也不会有问题

  

2.  ${ }变量替换 、 ${} 里面还可以有   #*,##*,#*,##*,% *,%% *

  一般情况下,$var与${var}是没有区别的,但是用${ }会比较精确的界定变量名称的范围。

  exp 1

[root@localhost ~]# A=Linux
[root@localhost ~]# echo $AB #表示变量AB [root@localhost ~]# echo ${A}B #表示变量A后连接着B
LinuxB

  截取变量的部分

file=/dir1/dir2/dir3/my.file.txt
可以用${ }分别替换得到不同的值:
${file#*/}: 删掉第一个 / 及其左边的字符串:dir1/dir2/dir3/my.file.txt
${file##*/}: 删掉最后一个 / 及其左边的字符串:my.file.txt
${file#*.}: 删掉第一个 . 及其左边的字符串:file.txt
${file##*.}: 删掉最后一个 . 及其左边的字符串:txt
${file%/*}: 删掉最后一个 / 及其右边的字符串:/dir1/dir2/dir3
${file%%/*}: 删掉第一个 / 及其右边的字符串:(空值)
${file%.*}: 删掉最后一个 . 及其右边的字符串:/dir1/dir2/dir3/my.file
${file%%.*}: 删掉第一个 . 及其右边的字符串:/dir1/dir2/dir3/my
记忆的方法为:
# 是 去掉左边(键盘上#在 $ 的左边)
%是去掉右边(键盘上% 在$ 的右边)
单一符号是最小匹配;两个符号是最大匹配

  取子串及替换

命令                                    解释                              结果
${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
${#file}           获取变量长度                  27

  

3.  $(( ))  可以 整数运算、进制转换、重定义变量值

bash中整数运算符号

符号 功能
+ - * / 分别为加、减、乘、除
% 余数运算
& | ^ ! 分别为“AND、OR、XOR、NOT”
[root@localhost ~]# echo $((*))

[root@localhost ~]# a=;b=;c=
[root@localhost ~]# echo $((a+b*c)) [root@localhost ~]# echo $(($a+$b*$c))

$(( ))可以将其他进制转成十进制数显示出来。用法如下:
echo $((N#xx))
其中,N为进制,xx为该进制下某个数值,命令执行后可以得到该进制数转成十进制后的值。

[root@localhost ~]# echo $((#))

[root@localhost ~]# echo $((#2a))

[root@localhost ~]# echo $((#))

(( ))重定义变量值,是 [] 数学表达式的加强版

[root@localhost ~]# a=;b=
[root@localhost ~]# ((a++))
[root@localhost ~]# echo $a [root@localhost ~]# ((a--));echo $a [root@localhost ~]# ((a<b));echo $? [root@localhost ~]# ((a>b));echo $?

4.  ${name[*]}    ${name[@]}     ${#name[*]}  区别

    在linux的shell里,${name}可以表示变量,也可以表示数组。

    name后面加〔〕的,一般是数组,

    ${name[*]}     是数组所有元素(all of the elements)

    ${name[@]}   是数组每一个元素(each of the elements)    ,循环数组用这个 。

    ${#name[*]}   是数组元素的个数,也可以写成  ${#name[@]}

    ${name:-Hello} 是指,如果${name}没有赋值,那么它等于Hello,如果赋值了,就保持原值,不用管问这个Hello了。

    ${!array_name[@]}     、${!array_name[*]}     获取数组的下标。

str="  114.114.114.114 2000:192:434:234 "

#变成数组
ip_list=(${str}) for i in "${!ip_list[@]}"; do
echo "@""$i=>${ip_list[i]}""@"
done echo "数组个数: ${#ip_list[@]}" echo "数组下标: ${!ip_list[@]}"

5. 单小括号 ()

  命令组。括号中的命令将会新开一个子shell顺序执行,所以括号中的变量不能够被脚本余下的部分使用。括号中多个命令之间用分号隔开,最后一个命令可以没有分号,各命令和括号之间不必有空格。

  命令替换。等同于`cmd`,shell扫描一遍命令行,发现了$(cmd)结构,便将$(cmd)中的cmd执行一次,得到其标准输出,再将此输出放到原来命令。有些shell不支持,如tcsh。

  用于初始化数组。如:array=(a b c d)   【($str) 会把字符串按照  字段分隔符:空格、制表符、换行符   ,分割形成 数组】

  参考  https://www.cnblogs.com/splendid/p/11201733.html

    

注意:

  [[ ]]  是 字符串表达式的加强版

随机推荐

  1. CodeForces985F -- Isomorphic Strings

    F. Isomorphic Strings time limit per test 3 seconds memory limit per test 256 megabytes input standa ...

  2. Node笔记 - process.cwd() 和 __dirname 的区别

    process.cwd() 返回工作目录  __dirname 返回脚本所在的目录位置 单看概念觉得都差不多,有种似懂非懂的感觉,那么接下用一个简单易懂的例子来理解下这两者的区别,在此之前先看一个方法 ...

  3. 最全的linux系统安装教程和排错方法

    第4章 linux信息和系统安装与连接    260 4.1 linux的发展历史    260 4.2 GPL协议,FSF协议    261 4.3 linux系统的安装    261 4.3.1 ...

  4. django学习02-模型的使用

    新手做的笔记,很可能会有理解错误的地方.欢迎拍砖. mysite/settings.py的INSTALLED_APPS选项中定义了几个默认的app,又如django.contrib.admin,dja ...

  5. Python文章相关性分析---金庸武侠小说分析-2018.1.16

    最近常听同事提及相关性分析,正巧看到这个google的开源库,并把相关操作与调试结果记录下来. 输出结果: 比较有意思的巧合是黄蓉使出打狗棒,郭靖就用了降龙十八掌,再后测试了名词的解析. 小说集可以百 ...

  6. usb fx2 cy68013 Cyapi使用心得

    Cyapi使用心得(1)--USB连接 用Cyapi也有一阵了,这个确实比EZusb的api好用,简单说下Cyapi的使用心得,在编程中应该注意的一些问题,毕竟,说起来,那个CYapi的说明文档讲的实 ...

  7. 利用用阿里云API实现DDNS

    前言 之前动态域名解析是用的是腾达路由器上集成的第三方动态解析服务花生壳,解析费用一年40元.后来觉得域名前缀不好,想换掉,花生壳需要重新购买新的域名解析费用,增加1条或者2条动态解析无所谓,万一以后 ...

  8. 《一头扎进》系列之Python+Selenium框架设计篇4- 价值好几K的框架,呵!这个框架有点意思啊

    1.简介 前面文章,我们实现了框架的一部分功能,包括日志类和浏览器引擎类的封装,今天我们继续封装一个基类和介绍如何实现POM.关于基类,是这样定义的:把一些常见的页面操作的selenium封装到bas ...

  9. linus 命令

    系统信息 arch 显示机器的处理器架构uname -m 显示机器的处理器架构uname -r 显示正在使用的内核版本 dmidecode -q 显示硬件系统部件 - (SMBIOS / DMI) h ...

  10. JavaSE-知识点总结

    Java名词 变量.运算符.类.接口.枚举.参数.注解.异常.包装类.多线程.集合.IO流.网络编程.反射.Lambda.API 源文件:.java文件,存储Java源代码的文件 字节码文件:.cla ...