危险字符通常是指_收藏 | 15 个你非了解不可的 Linux 特殊字符

不知道大家接触 Linux 系统有多久了,可曾了解过 Linux 中有哪些特殊的字符呢?其实啊,那些特殊字符都大有用处呢,今天的文章就给大家简单地科普一下 Linux 中你需要了解的 15 个特殊字符,想学或刚学 Linux 的小伙伴赶紧上车了为!

~ 主目录

这个波浪号 ~ 指的是主目录,也就是我们用户的个人目录,无论你身在何方,输入 cd ~ 它将带你回家!

cd ~
c99b5c2893628009b8cff90c0b158608.png

更高端的玩法就是在它后面加上具体的路径,直接定位到家目录中的指定位置,是不是很方便呢?

cd ~/work/archive
6673f1382bc89773e19a73efd178eae6.png
. 当前目录

英文句号 . 代表当前目录,我们来看一下当前目录下的全部文件:

ls -al
9d6dbc549aaf26d4ca392a67e23ea434.png

红圈里的 . 就是指当前目录,不过这没什么意义,我们更多的是在命令中使用它,如下:

./script.sh

这样做是在告诉 bash 只要在当前目录中查找并执行 script.sh 文件就好了,不用在路径中找了。

1d52b71d2b19ce2b419603951b47af46.png
.. 父目录

两个英文句号 .. 代表父目录,也就是当前目录的上一级目录。假设我们要回到上一级目录:

cd ..
ddefc4d15a96772b78bc2b3358e2525e.png

跟前面一样,你可以在它后面加具体的目录,这里的意思就是定位到与当前目录同级的其它目录:

cd ../projects/
4214174566e4dbef07199379f1652e68.png
/ 路径目录分隔符

斜杠 "/" 指的是路径目录分隔符,这里没什么好说的。

ls ~/work/tests/
b63aef8f9296a444341f1b08d850c99e.png

但是,有意思的是,如果 / 路径目录分隔符前面没有东西的话,是不是就是意味着这是最上级的目录了?由于 Linux 系统的目录树均始于 / ,所以仅仅一个 / 代表了我们常说的系统根目录

cd /
447634b980054fe7292b74a268eb83a0.png
# 注释

# 开头,代表这句话是注释

# This will be ignored by the Bash shell
cb2152cafb238dd6f9725fd09537c417.png

虽然上面那段话就被忽略了,但它还是会添加到您的命令历史记录中。

更厉害的做法如下:

先定义一个变量并给它赋值字符串 “amazing alvin”

this_string="amazing alvin"
7efb33dd75783deba517c321d2d38b7a.png

${this_string#amazing} 返回的是被注释掉 amazing 的 this_string 字符串变量,可以 echo 输出看下结果:

echo awsome ${this_string#amazing}
8bab4b928f339a2a3965791b77f15011.png

amazing 只是被注释掉而已,它并未被删除,去掉注释它就回来了:

echo $this_string
c5e593e1fec80e0bd72f58b1092fa79a.png
? 单字符通配符

问号 "?",指的是单字符通配符。Bash Shell 支持三种通配符。

它代表文件名中任意一个字符的匹配,例如:

ls badge?.txt
bbfef0c3f43ef1a7b3c14a1cf691fd24.png

注意,它与 badge.txt 是不匹配滴,因为 badge 后面没有字符。

正因为 "?" 匹配单个字符,所以这里有个看似很厉害的玩法,就是你想要的找的文件的文件名有多少个字符,你就输入多少个 "?"

ls ?????.txt
fe3f2e01553f11b3906967260cc05564.png

看着挺厉害,不过我怎么感觉这好别扭?????

* 字符序列通配符

星号 * 代表的是任意字符序列匹配任意字符,包括空字符,以刚才的 badge 为例:

ls badge*
e54ed9a3d9a049cc4fac47a328e3a726.png

可以看到,badge.txt 都匹配到了。

匹配任意类型的文件:

ls source.*
[] 字符集通配符

方括号 "[]" 指的是字符集通配符,文件名中的相关字符必须与字符集中的至少一个字符匹配。通过例子来体会一下它的作用吧:

ls badge_0[246].txt
e95a591a616f03bc41c74d5535e350c3.png
ls badge_[01][789].txt
064cc9a7a52e9857b4ae7cc8b1baf488.png
ls badge_[23][1-5].txt
df3c304725f083c8d08038f5aabd0590.png
; 命令分隔符

这跟我们日常使用的 ";" 差不多,就不细说了,主要是用来分隔命令的。

ls > count.txt; wc -l count.txt; rm count.txt
a387ab5c4fc26f9c654e13c30b80c3d3.png

这里注意,用 ; 分隔命令时,即使第一个命令失败,第二个命令也会运行,即使第二个命令失败,第三个命令也会运行,依此类推。

如果要在一个命令失败的情况下就停止,请使用 "&&" ,如下:

cd ./doesntexist && cp ~/Documents/reports/* .
4c0b050176d7e4dfde58c47dce70efa6.png
& 后台处理

有时候在终端正在运行一个命令时,例如 vim,你想运行另外一个命令怎么办?这里有个小技巧就是在命令后面加一个 "&" 符号,将这个程序放在后台启动,这样你就能在终端实现后台多任务的效果了。

vim command_address.page &
40174e15124c0f649cbdc2f67abf4d8e.png

上面显示的是这个后台进程的 ID 。

< 输入重定向

许多 Linux 命令接受一个文件作为参数,并从该文件中获取数据。这些命令中的大多数还可以从流中获取输入。要创建一个流,可以使用左尖括号 " ,如下将文件重定向到命令中:

sort < words.txt
da1af377aa6756ce429c433ec20e7132.png

上面将 words.txt 文件的内容并进行了排序。

注意:它是不显示数据来源文件的文件名的。

wc words.txt
wc < words.txt
3b6b591e976bd66007ea683e9d1c5a48.png
> 输出重定向

输入和输出是相反的,很好理解。用右尖括号 ">" 将命令的输出重定向,通常是重定向到文件中

ls > files.txt
cat files.txt
cbf919e80299929fa2ce4d0bdf250a26.png

高端玩家还可以和数字一同使用:

wc doesntexist.txt 2> errors.txt
cat errors.txt
56b070d53b3fb6bad1fe0ead57324dbc.png

这里的 2 是一个文件描述符,表示标准错误(stderr)

大家感兴趣的可以去搜索下文件描述符 stdin,stdout,stderr 是什么?

| 连接命令

我们可以将 " | " 看成将命令链接在一起的管道。它从一个命令获取输出,并将其作为输入送入下一个命令。管道命令的数量是任意的。

cat words.txt | grep [cC] | sort -r
6461f3b59d9f798ddb1b432ef05e61f7.png

解释下,上面先使用 cat 将 words.txt 文件的内容输入 grep , 然后 grep 提取包含小写或大写(C/c)的任何行,接着 grep 将这些行传递给 sort ,最后 sort 进行 -r 反向排序。

! 逻辑非

这跟编程语言中的 " ! " 差不多,我们直接拿个例子来说吧:

[ ! -d ./backup ] && mkdir ./backup

第一个命令 -d 判断当前目录是否存在 backup 的目录文件,外面加个逻辑非 ! 判断,
第二个命令是创建 backup 目录文件,
中间的 && 上面说过。
总的来说就是当 backup 目录不存在时,创建 backup 目录;当不存在时则不执行第二条命令。

不妨看下文件夹的备份状态:

ls -l -d backup
6f788a56d58fef44b3bc3d150ecc7b84.png

" ! " 的另一个用法就是重新运行历史命令:

!24
!!
95c15388d9813217145c5a5707d2c320.png

" !! " 是重新运行上一条命令的意思。

$ 变量表达式

"$" 开头通常表示变量,下面是一些系统变量:

echo $USER
echo $HOME
echo $PATH
afaff31a7776e059c37732e2aff77fed.png

当然,你也可以自己定义变量然后输出:

ThisDistro=Ubuntu
MyNumber=2001
echo $ThisDistro
echo $MyNumber
46457a81dc242e3df0516494b5aae0ea.png

我们还可以通过 "{}" 解锁更高级的玩法:

先定义一个变量 MyString 并给它赋值 123456qwerty

MyString=123456qwerty

正常输出

echo ${MyString}

加个 ":6" 返回从索引位置 6 开始的一直到最后的字符串

echo ${MyString:6}

显示从索引位置从 0 开始往后 6 个字符的字符串

echo ${MyString:0:6}

显示从索引位置从 4 开始往后 4 个字符的字符串

echo ${MyString:4:4}
21123232db057c5732191042e1664d45.png
引用特殊字符

说了那么多,那么就有个问题了,就是我只想在命令里面将这些特殊字符作为一般的符号显示怎么办?这种我们称之为引用,Linux 中有三种引用方法。

用双引号 "" 括起来,不过这对 "$" 无效。

echo "Today is $(date)"

用单引号 '' 括起来,停止所有特殊字符的功能

echo 'Today is $(date)'

反斜杠 转义,这在很多场合都有通用的。

echo "Today is $(date)"
59d72f2c35ad5da3c95503f20d95dd75.png

今天的科普文章有点长,大家慢慢消化哈。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值