shell函数与自带变量

这篇博客详细介绍了Linux shell脚本中的特殊变量,如$#, $$, $*等,以及参数重定向、二元比较运算符(-eq, -ne, -gt等)和文件测试(-e, -f, -d等)。此外,还涵盖了参数替换和扩展,如${var默认值}

1,特殊shell变量
$# 传递到脚本的参数个数
$* 以一个单字符串显示所有向脚本传递的参数
$$ 脚本运行的当前进程ID号
$! 后台运行的最后一个进程的ID号
@与@ 与@*相同,但是使用时加引号,并在引号中返回每个参数。
$- 显示Shell使用的当前选项,与set命令功能相同。
$? 显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误。
$_ 显示传参的最后一个参数

command > file 将输出重定向到 file。
command < file 将输入重定向到 file。
command >> file 将输出以追加的方式重定向到 file。
n > file 将文件描述符为 n 的文件重定向到 file。
n >> file 将文件描述符为 n 的文件以追加的方式重定向到 file。
n >& m 将输出文件 m 和 n 合并。
n <& m 将输入文件 m 和 n 合并。
<< tag 将开始标记 tag 和结束标记 tag 之间的内容作为输入。

$ command > /dev/null
/dev/null 是一个特殊的文件,写入到它的内容都会被丢弃;如果尝试从该文件读取内容,那么什么也读不到。但是 /dev/null 文件非常有用,将命令的输出重定向到它,会起到"禁止输出"的效果。
如果希望屏蔽 stdout 和 $ command > /dev/null 2>&1

$0 脚 本名字
$1 位置参数 #1
$2 - $9 位置参数 #2 - #9
${10} 位置参数 #10
KaTeX parse error: Expected 'EOF', got '#' at position 1: #̲ 位置参数的个数 "" 所有的位置参数(作为单个字符串) *
“$@” 所有的位置参数(每个都作为独立的字符串)
${#
} 传递到脚本中的命令行参数的个数
${#@} 传递到脚本中的命令行参数的个数
$? 返回值
$$ 脚本的进程ID(PID)
$- 传递到脚本中的标志(使用set)
$_ 之前命令的最后一个参数
$! 运行在后台的最后一个作业的进程ID(PID)

2,二元比较
-eq   等于
=    等于
==   等于
-ne   不等于
!=    不等于
-lt    小于
<    小于 (ASCII) *
-le    小于等于
-gt    大于
>    大于 (ASCII) *
-ge  大于等于
-z    字符串为空
-n    字符串不为空

大于
=   大于等于
<   小于
<=   小于等于

3,文件测试类型
-e   文件是否存在
-s   文件大小不为0
-f   是一个标准文件
-d   是一个目录
-r   文件具有读权限
-w   文件具有写权限
-x   文件具有执行权限
-h   文件是一个符号链接
-L   文件是一个符号链接
-b   文件是一个块设备
-c   文件是一个字符设备
-g   设置了sgid标记
-p   文件是一个管道
-u   设置了suid标记
-S   文件是一个socket
-k   设置了"粘贴位"
-t   文件与一个终端相关联
-N   从这个文件最后一次被读取之后, 它被修改过
-O   这个文件的宿主是你
-G   文件的组id与你所属的组相同
F1 -nt F2 文件F1比文件F2新 *
F1 -ot F2 文件F1比文件F2旧 *
F1 -ef F2 文件F1和文件F2都是同一个文件的硬链接 *

! “非” (反转上边的测试结果)

4,参数替换和扩展
表达式 含义
var变量var的值,与{var} 变量var的 值, 与varvar,var相同

var−DEFAULT如果var没有被声明,那么就以{var-DEFAULT} 如果var没 有被声明, 那么就以varDEFAULTvar,DEFAULT作为其值 *
var:−DEFAULT如果var没有被声明,或者其值为空,那么就以{var:-DEFAULT} 如果var没 有被声明, 或者其值为空, 那么就以var:DEFAULTvar,,DEFAULT作为其值 *

var=DEFAULT如果var没有被声明,那么就以{var=DEFAULT} 如果var没 有被声明, 那么就以var=DEFAULTvar,DEFAULT作为其值 *
var:=DEFAULT如果var没有被声明,或者其值为空,那么就以{var:=DEFAULT} 如果var没 有被声明, 或者其值为空, 那么就以var:=DEFAULTvar,,DEFAULT作为其值 *

var+OTHER如果var声明了,那么其值就是{var+OTHER} 如果var声 明了, 那么其值就是var+OTHERvar,OTHER, 否则就为null字符串
var:+OTHER如果var被设置了,那么其值就是{var:+OTHER} 如 果var被设置了, 那么其值就是var:+OTHERvar,OTHER, 否则就为null字符串

var?ERRMSG如果var没被声明,那么就打印{var?ERR_MSG} 如果var没 被声明, 那么就打印var?ERRMSGvar,ERR_MSG *
var:?ERRMSG如果var没被设置,那么就打印{var:?ERR_MSG} 如果var没 被设置, 那么就打印var:?ERRMSGvar,ERR_MSG *

${!varprefix*} 匹配之前所有以varprefix开头进行声明的变量
${!varprefix@} 匹配之前所有以varprefix开头进行声明的变量

${#string} $string的 长度

string:position在{string:position} 在string:positionstring中, 从位置$position开始提取子串
string:position:length在{string:position:length} 在string:position:lengthstring中, 从位置position开始提取长度为position开始提取长度为positionlength的子串

KaTeX parse error: Expected '}', got '#' at position 8: {string#̲substring} 从 变量string的开头, 删除最短匹配$substring的子串
KaTeX parse error: Expected '}', got '#' at position 8: {string#̲#substring} 从 变…string的开头, 删除最长匹配$substring的子串
KaTeX parse error: Expected '}', got 'EOF' at end of input: …substring} 从 变量string的结尾, 删除最短匹配$substring的子串
KaTeX parse error: Expected '}', got 'EOF' at end of input: …substring} 从 变量string的结尾, 删除最长匹配$substring的子串

string/substring/replacement使用{string/substring/replacement} 使用string/substring/replacement使replacement, 来代替第一个匹配的$substring
string//substring/replacement使用{string//substring/replacement} 使 用string//substring/replacement使replacement, 代替所有匹配的$substring
KaTeX parse error: Expected '}', got '#' at position 9: {string/#̲substring/repla…string的前缀匹配substring,那么就用substring, 那么就用substring,replacement来代替匹配到的$substring
KaTeX parse error: Expected '}', got 'EOF' at end of input: …replacement} 如果string的后缀匹配substring,那么就用substring, 那么就用substring,replacement来代替匹配到的$substring

expr match "string"′string" 'string"substring’ 匹配string开头的string开头的stringsubstring* 的长度
expr "string":′string" : 'string":substring’ 匹 配string开头的string开头的stringsubstring* 的长度
expr index “$string” substring在substring 在substringstring中匹配到的$substring的第一个字符出现的位置
expr substr $string $position length在length 在lengthstring中 从位置position开始提取长度为position开始提取长度为positionlength的子串
expr match "KaTeX parse error: Can't use function '\(' in math mode at position 10: string" '\̲(̲substring)’ 从string的开头位置提取string的 开头位置提取stringsubstring*
expr "KaTeX parse error: Can't use function '\(' in math mode at position 12: string" : '\̲(̲substring)’ 从string的开头位置提取string的 开头位置提取stringsubstring*
expr match "KaTeX parse error: Can't use function '\(' in math mode at position 12: string" '.*\̲(̲substring)’ 从string的结尾提取string的 结尾提取stringsubstring*
expr "KaTeX parse error: Can't use function '\(' in math mode at position 14: string" : '.*\̲(̲substring)’ 从string的结尾提取string的 结尾提取stringsubstring*

5,中 括号
if [ CONDITION ] 测 试结构

if [[ CONDITION ]] 扩 展的测试结构

Array[1]=element1 数 组初始化

[a-z] 正 则表达式的字符范围

6,大括号

${variable} 参数替换

${!variable} 间 接变量引用

{ command1; command2; . . . commandN; } 代码块

{string1,string2,string3,…} 大 括号扩展

7, 圆括号

( command1; command2 ) 子shell中 执行的命令组

Array=(element1 element2 element3) 数组初始化

result=$(COMMAND) 在 子shell中执行命令, 并将结果赋值给变量

(COMMAND) 进 程替换

<(COMMAND) 进 程替换

8,双圆括号

(( var = 78 )) 整型运算

var=$(( 20 + 5 )) 整型运算, 并将结果赋值给变量

9,引 号

“$variable” " 弱"引用 ‘string’ "强"引用

10,后 置引用

result=COMMAND 在 子shell中运行命令, 并将结果赋值给变量

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sh13661847134

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值