简介

    这篇文章主要介绍shell中的一些常用符号和它们的各自用法,包括搭配命令的符号用法、shell 脚本中的符号用法。在这篇文章中对这些符号做大致的解释,详细的用法在对应目录下增加其他文章的超链接。

         

目录

1. 搭配命令类

1.1. ` `命令输出

1.2. * 通配符

1.3. cd 常用命令

1.4. & 后台命令

1.5. > 输出重定向

1.6. !历史符

2. shell类型

2.1. # 注释

2.2. $符号

2.3. ( ) 圆括号

① 表示命令

② 表示数组

③ 表示计算器

④ 表示循环

2.4. [ ] 方括号

① 表示计算器

② if 判断语句 

③ 双括号判断

2.5. { } 花括号

① 接收变量/数组

② 指定分隔符截取字符串

③ 指定索引截取字符串

④ 判断变量是否为空

2.4. " " 引号

2.5. 正则表达式符号

2.6. 其他符号

3. Linux 后缀名


        

1. 搭配命令类

  • 时常搭配命令使用的符号包括:``、*、-、/、&、|、>、!等。

1.1. ` `命令输出

这个符号可以在命令中执行另一个命令

df -h `pwd`    # 查看当前路径下的磁盘占用情况

它等同于

        

这个符号与 $( ) 的效果也是一样的,比如

        

所以它们可以相互嵌套

path=$(dirname `realpath $0`)
echo ${path}

        

1.2. * 通配符

这个符号是正则表达式中匹配0或多个字符,搭配命令可以这样使用

ll *.txt    # 查看以txt结尾的文件
ll *.sh     # 查看以sh结尾的文件
ll file*    # 查看以file开头的文件
ll *1*      # 查看包含1的文件

        

除了 ll 命令,搭配其他命令也是一样的效果

find ./ -name "*.sh"

        

1.3. cd 常用命令

cd 常用命令如下

cd        # 进入家目录
cd ~      # 进入家目录
cd /      # 进入根目录
cd -      # 返回上一次目录
cd ..     # 进入上一级目录
cd ../..  # 进入上上级目录

        

1.4. & 后台命令

这里的后台命令就是指:将某个命令或脚本放到后台执行,使得在执行过程中不阻塞当前终端。语法如下:

# 写法一
[命令] &
# 写法二
nohup [命令] &

两种写法都可以,但存在根本上的区别。直接使用 命令 & 推到后台执行后,当前终端窗口断开,那么后台命令自动退出;使用 nohup 命令 & 推到后台,当前终端窗口断开也不会退出。

举个例子

sleep 10 &

我们执行一个 sleep 命令后会自动被推到后台执行,并显示PID,通过PID可以查询该进程正在运行。

        

与后台相关的其他命令如下:

jobs    # 查看当前窗口执行的后台命令
fg [id] # 将作业切换到前台
bg [id] # 将作业切换到后台

在其他文章中介绍了使用 & 实现子进程和一些管理见链接:shell子进程管理-CSDN博客

        

1.5. > 输出重定向

什么是重定向呢?

就是将某个命令或脚本的输出的内容定向到其他地方,这个地方可以是一个文件,也可以是 null。举个例子:将 ls 的内容重定向到一个文件中

ls > tmp.log

可以看到,正常情况下 ls 显示了当前目录下的文件/文件夹,但是使用 > 重定向到另一个文件中,则当前终端就不会再显示,而是把输出都放到了 tmp.log 中。

        

除了 > 外,我们还有 一些其他的用法

>    # 将内容覆盖到文件
>>   # 将内容追加到文件
>/dev/null    # 将正常的内容输出为空
1>/dev/null   # 将正常的内容输出为空
2>/dev/null   # 将异常的内容输出为空
&>/dev/null   # 将全部内容输出为空(包括正常和异常)

大部分 shell 重定向在上述方法都能实现,但如果希望内容既输出到终端,又输出到文件怎么做呢?这时候需要借助一个命令 tee

tee [文件]     # 将内容覆盖到文件
tee -a [文件]  # 将内容追加到文件

举个例子,将 abc 输出到文件

将 abc 输出到屏幕,并且追加到文件

        

1.6. !历史符

!在平时使用是比较多的,先来看看常用方法

!!    # 执行上一个命令
!p    # 执行上一次以p开头的命令
!20   # 执行历史命令编号为20的命令(使用 history 查看编号)

【案例一】执行上一次命令 !!

第1行显示上一个命令是什么,后面的才是执行结果

        

【案例二】执行上一个以 d 开头的命令 !d

执行最后一次以 d 开头的命令

        

2. shell类型

2.1. # 注释

单行注释

以井号开头
# 注释内容xxx

        

多行注释

以 << 开头 + 开始语,最后以开头语一样的字符结尾
<<EOF
    注释内容1
    注释内容2
    注释内容3
EOF

        

vim 命令多行注释

# 末行模式 - 注释整个文件
:%s/^/#/

# 末行模式 - 注释指定行(3-5行)
:3,5s/^/#/

# 命令模式 - 选中注释
    1、光标移动到指定行
    2、Ctrl + v
    3、上下键选中指定行
    4、按下大写 I 键
    5、按下井号键 #
    6、按下ESC退出键

        

2.2. $符号

  • 包含变量名、脚本名、位置参数
符号解释
$$表示当前脚本 PID
$*表示所有的位置参数
$@表示所有的位置参数
$#表示参数个数
$?返回上一个指令的状态(0表示正常,其他数字表示异常)
$!表示上个后台运行的PID
$0表示当前脚本名
$1表示第1个位置参数
$2表示第2个位置参数
$n表示第n个位置参数

        

注意:$n 表示位置参数。如果在全局表示脚本的位置参数

#!/bin/bash
echo $1 $2

  

如果在函数中则表示函数的位置参数

#!/bin/bash
function f1(){
    echo $1 $2
    }
f1 "ABC" "YT"

        

除了上述的常见用法,还有一些系统内置的变量

符号解释
$USER当前用户的用户名
$HOME当前用户的主目录
$PWD当前工作目录的绝对路径
$OLDPWD上一个工作目录的绝对路径
$HOSTNAME当前主机的主机名
$SECONDSShell启动后的秒数
$RANDOM一个随机数
$LINENO当前代码行的行号
$IFS输入分隔符
$PS1主提示符的字符串
$PS2次提示符的字符串

详细见另一篇文章:shell 编程中内置的变量(冷门又好用)

        

2.3. ( ) 圆括号

① 表示命令

# $() 表示输出命令,等同于反引号``
df -h $(pwd)    # 命令中套用命令


# 获取绝对路径的目录(不包含文件)
dirname [路径]

# 获取路径下文件名
basename [路径]

# 获取当前脚本的上层绝对路径
echo `cd $(dirname ${BASH_SOURCE}); pwd`

# 将三个命令看做一个大整体,那么括号中视为一个小整体
command1 (command2 command3)

        

② 表示数组

# 顺序索引添加数组
arr=(a1 a2 a3)        # 默认索引从0开始,以空格分隔

# 指定索引添加数组
arr=([1]="a1" [4]="a4")

# 替换/添加指定的索引
arr[1]="arr1"         # 将索引为 1 的值替换为 arr1,若原索引1为空,那么直接添加

# 拼接两个数组
arr1=(a1 b1)  arr2=(a2 b2)
arr3=(${arr1[@]} ${arr2[1]})  # arr1 全部 + arr2 索引 1
echo ${arr3[@]}               # a1 b1 b2

# 删除数组
unset arr1[0]         # 将 arr1 索引为 0 的值删除

# 输出数组
echo ${arr}           # 输出第一个数组
echo ${arr[0]}        # 输出第一个数组
echo ${arr[1]}        # 输出第二个数组
echo ${arr[@]}        # 输出全部数组
echo ${#arr[@]}       # 输出数组的个数

# 数组排序
arr=(1 342 23 54)
arr=($(echo ${arr[@]} |xargs -n 1 |sort -n|xargs))    # 升序
arr=($(echo ${arr[@]} |xargs -n 1 |sort -nr|xargs))   # 降序

详细的数组用法见另一篇文章:shell 数组的详细用法-CSDN博客 

        

③ 表示计算器

计算两个值
echo $(( 1 + 1 ))    # 2

计算两个变量相加的值
a=2
b=3
echo $(( a + b ))    # 5

注意:这种方式无法计算浮点数,系统会直接省略,可以使用 echo + bc 命令

指定浮点数位数:scale
echo "scale=2; 10 / 3" |bc    # 3.33
echo "scale=2; 1 + 1.234" |bc # 2.234 浮点数相加无法指定

详细的计算器用法见另一篇文章:shell 计算器-CSDN博客

        

④ 表示循环

# for 循环
for (( i=1; i<10; i+=1 ));do
        echo $i
done

# 加法
w=0
while [ ${w} -le 10 ] ;do
        echo ${w}
        (( w += 1 ))
done

详细的循环见另一篇文章:shell 循环遍历的详细用法-CSDN博客

        

2.4. [ ] 方括号

① 表示计算器

计算两个值
echo $[ 1 + 1 ]    # 2

计算两个变量相加的值
a=2
b=3
echo $[ a + b ]    # 5

注意:这种方式无法计算浮点数,系统会直接省略,可以使用 echo + bc 命令

指定浮点数位数:scale
echo "scale=2; 10 / 3" |bc    # 3.33
echo "scale=2; 1 + 1.234" |bc # 2.234 浮点数相加无法指定

        

② if 判断语句 

********************** 逻辑符判断 **************************
判断:真
[ -f /data ] && echo "如果有 /data 这个文件,那么输出这段字符串"

判断:假
[ ! -f /data ] && echo "如果没有 /data 这个文件,那么输出这段字符串"

合理利用逻辑操作符:&& 输出真,|| 输出假
[ -f /data ] && echo "这个文件存在" || echo "这个文件不存在"

********************** if 语句判断 ************************
判断上一个指令是否正常
if [ $? -eq 0 ]; then
    echo "上一个指令输出正常"
else
    echo "上一个指令输出异常, 退出程序"
    exit 1
fi

判断多个指令:-a 表示逻辑与(and)
if [ f1 -eq 1 -a f2 -eq 2 ]; then
    echo "f1=1,f2=2 必须满足两个条件即可"
else
    echo "不满足两个条件"
fi

判断多个指令:-o 表示逻辑或(or)
if [ f1 -eq 1 -o f2 -eq 2 ]; then
    echo "f1=1,f2=2 满足其中一个条件即可"
else
    echo "不满足两个条件"
fi

********** 逻辑比较参数 **********

Usage:[ 1 -eq 1 -a 2 -eq 2 ]

-a:逻辑与(and)

-o:逻辑或(or)

********** 数学比较参数 **********
Usage:[ 1 -eq 1 ]
-gt :大于
-eq:等于
-lt  :小于
-ne:不等于
-ge:大于等于
-le :小于等于

********** 字符串比较参数 ********
Usage:[ "string" == "string" ]
==:等于
!=:不等于

********** 文件比较与检查 ********
Usage:[ -f file.txt ]
-f:判断文件存在
-d:判断目录存在
-e:判断文件或目录存在
-z:判断字符串为空
-n:判断字符串不为空
-r:判断文件为可读
-w:判断文件为可写
-x:判断文件为可执行
-s:判断文件存在,且不为空
-O:判断文件存在,且被当前用户拥有
-G:判断文件存在,且默认组为当前用户组
file1 -nt file2:判断文件 file1 比 file2 新
file1 -ot file2:判断文件 file1 比 file2 旧

详细的判断方法见另一篇文章:shell if判断的应用方法-CSDN博客

        

③ 双括号判断

判断变量是否为空
[[ ! ${var} ]] && echo "变量 var 为空"

数据运算判断 >、=、<、!=、>=、<=
if [[ ${a} > 1 ]]; then
    echo "变量 a 大于 1"
else
    echo "变量 a 不大于 1"
fi

字符串判断
if [[ "${var}" == "string" ]]; then
    echo "变量 var 等于 string"
else
    echo "变量 var 不等于 string"
fi

逻辑判断:&& 与、|| 或、!非
[[ 1=1 && 2=2 && 3=3 ]] && echo "需要满足全部条件"
[[ 1=1 || 2=1 || 3=1 ]] && echo "满足其中一个条件即可"
[[ ! 1=1 ]] && 1 不等于 1(取反)

        

2.5. { } 花括号

① 接收变量/数组

符号解释
${var}表示接收的变量(标准写法),也可以写 $var
${a[1]}输出数组 a 索引为 1 的值
${a[-1]}输出数组 a 最后1个值,-2 表示倒数第2个
${a[@]}输出全部数组
${#a[@]}输出数组的个数
${#a[0]}输出数组索引为0的字符长度
${a[@]:2:6}输出数组索引为 2 后面的 6 个值
${a[@]::3}输出数组索引为 3 之前的值(0,1,2)
${a[@]:$((pos + 2))}输出索引为 2 后面的所有值(包含索引2)

详细的数组使用方法见另一篇文章:shell 数组的详细用法-CSDN博客 

        

② 指定分隔符截取字符串

符号解释
${a#*/}指定分隔符为 /,不显示第一列
${a##*/}指定分隔符为 /,只显示最后1列
${a%/*}指定分隔符为 /,不显示最后一列
${a%%/*}指定分隔符为 /,只显示第一列
示例:a=1/2/3/4/5
echo ${a#*/}         # 2/3/4/5
echo ${a##*/}        # 5
echo ${a%/*}         # 1/2/3/4
echo ${a%%/*}        # 1

详细的字符串处理方法见另一篇文章:shell 变量、字符串的处理方法-CSDN博客

        

③ 指定索引截取字符串

符号解释
${a:1}截取字符串索引为1开始,后面全部
${a:1:2}截取字符串索引为1开始,后面 2 个
${a:0-1}截取字符串最后1个
${a:0-2}截取字符串最后2个
${a:0-5:3}0-5获取最后5个,:3 从5个值中从左到右截取3个

        

④ 判断变量是否为空

符号解释
${a:-'1'}如果变量 a 为空,那么返回1(1可以为任意字符串)
${a:='1'}如果变量 a 为空,那么给a赋值为1(1可以为任意字符串)
${a:?'error'}如果变量 a 为空,那么退出程序,输出字符串 error(error 可以为任意字符串)

        

2.4. " " 引号

单引号:单引号内的任意字样都会被原样输出,无法使用变量、转译等操作

        

双引号:双引号内可以使用变量、转译、通配符

        

反引号:输出命令 (同 $() 一样)

        

2.5. 正则表达式符号

  • Linux 中 grep、awk、sed 等命令支持正则表达式
字符解释用法
^匹配以什么开始grep -E '^ab' 匹配以ab开头的行
$匹配以什么结尾grep -E 'ab$' 匹配以ab结尾的行
.匹配任意一个字符grep -E 'a.c' 只匹配a与c之间拥有一个字符的行
.+匹配1次或多次grep -E 'a.+c' 匹配a与c之间任意字符的行,不包含ac
*匹配0次或多次grep -E 'a*c' 匹配a与c之间任意字符的行,包含ac
|相当于 orgrep -E 'ab|ac' 匹配包含ab或ac的行
[]匹配括号中任意一个字符grep -E '[ac]' 匹配包含a或c的行
[^]匹配非括号中任意一个字符grep -E '[^ac]' 匹配不包含a或c的行
-[0-9] 匹配数字grep -E [0-9]   匹配包含数字的行
[^0-9] 匹配非数字grep -E [^0-9] 匹配不包含数字的行
[a-z] 匹配小写字符串grep -E [a-z]   匹配包含小写字符串的行
[^a-z] 匹配非小写字符串grep -E [^a-z] 匹配不包含小写字符串的行
[A-Z] 匹配大写字符串grep -E [A-Z]   匹配包含大写字符串的行
[^A-Z] 匹配非大写字符串grep -E [^A-Z] 匹配不包含大写字符串的行
()(a|b) 匹配括号中任意字符grep -E '0(a|b)1' 只匹配0a1和0b1的行
(a)+ 匹配包含1个或多个agrep -E '0(a)+1' 匹配0和1之前1个或多个a,0a1、0aa1...
{}{n} 指定匹配n个以上grep -E 'ab{2}' 匹配包含ab,且a或b连续为2次以上:abb
{n,m} 指定匹配 n-m 个grep -E 'ab{2,3}' 匹配包含ab,且a或b连续为2-3次:abb、aaab

这3个命令的详细用法将其他文章:

Linux命令_grep & 快速查找关键字、文件名

Linux命令_awk & 字符串过滤、文件过滤

Linux命令_sed & 快速修改、删除、增加、过滤文件内容

        

2.6. 其他符号

\	转译字符,以下常用 3 个作用:
        1、将特殊符号转译为普通符号:\$、\[、\*、\\
        2、某些命令特殊定义:\n 换行、\t 缩进、\r 回车
        3、连接多个命令:用于shell格式调整(命令过长使用 \ 符号,下一行命令延续上一行命令)
:	表示什么也不做,相当于占位符
;	表示将命令分开(例如: ls aaa; ls bbb  执行完成第一个命令后继续执行第二命令)
;;	用于 case 命令专属

        

3. Linux 后缀名

类型后缀解释
脚本文件.shshell 文件
.pypython 文件
.jarjava 文件
.cc 语言文件
.cppc++ 文件
.hc 或 c++ 头部文件
.o程序目标文件
.phpphp 文件
.tcltcl 文件
.exp交互命令 expect 文件
系统文件.so库文件
.rpmrpm 包
压缩包.tartar 包
.zipzip 包
.tar.gzgzip 包
应用文件.conf配置文件
.sqlsql 文件
普通文件.htmlhtml 文件
.txt文本文件
图像文件.gifGIF 图像文件
.pngPNG 图像文件
.xpmXPM 图像文件

        

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐