Linux符号大全

2025-07-12 02:17:47

简介

这篇文章主要介绍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

多行注释

以 << 开头 + 开始语,最后以开头语一样的字符结尾

<

注释内容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 图像文件