老亚瑟比较喜欢用cheat sheet(备忘录)的方式学习一些编程里零散但又经常会用到的知识点。相比于冗长详尽的博客,这种方式既简单轻量,同时每次查看的时候可以通过大脑对知识进行自动补全,能不断提升对应知识点的记忆。但是缺点也很明显,就是讲述不够细致全面。所以,如果读者对相关cheat sheet的知识储备太少的话,建议先系统学习。
下面是我学习和使用Linux shell时的cheat sheet。
test = [ ] 这两个是shell 程序
[[ ]] 这个是shell 关键字
" " 双引号中可以使用$对变量取值
' ' 单引号中所有字符均表示字面值,无法用$取值
[[ "$s1" != "$s2" ]] [ "$s1" != "$s2" ]
[[ "$s1" == "$s2" ]] [ "$s1" == "$s2" ]
[[ "$s1" = "$s2" ]] [ "$s1" = "$s2" ]
[[ "$s1" > "$s2" ]] [ "$s1" \> "$s2" ]
[[ "$s1" < "$s2" ]] [ "$s1" \< "$s2" ]
-eq -ne
-gt -ge
-lt -le
v=7.6
if [ $(echo "$v >= 8" | bc) -eq 1 ]; then
if [ `echo "$v >= 8" | bc` -eq 1 ]; then
if [ `echo "$v" | awk '{if($1>=8) print 1; else print 0;}'` -eq 1 ]; then
if [ `echo "$v" | awk '{print ($1>=8)?1:0}'` -eq 1 ]; then
-z True for zero
-n True for non-zero
-e True for file exist
-f True for normal file exist
-d True for dir exist
-c True for char file exist
-b True for block file exist
-p True for pipe file exist
-S True for socket file exist
-L/-h True for symbol link exist
-r/w/x True for readable/writable/executable file exist
[[ cond-a && cond-b ]] [ cond-a -a cond-b ]
[[ cond-a || cond-b ]] [ cond-a -o cond-b ]
[[ ! cond ]] [ ! cond ]
[[ "$ss" =~ regex ]] && echo ${BASH_REMATCH[1]}
只能用双中括号,单中括号不行
if TEST-COMMANDS; then
CONSEQUENT-COMMANDS
elif TEST-COMMANDS; then
CONSEQUENT-COMMANDS
else
CONSEQUENT-COMMANDS
fi
for i in “file1” “file2” “file3”
for i in /boot/*
for i in /etc/*.conf
for i in $(seq -w 10)
for i in {1..10}
for i in $(ls)
for i in $(< file)
for i in "$@"
for ((i=0; i<5; i++))
do
commands
done
while read -r line
do
commands
done < "path/to/file"
while getopts :xy: opt
do
case "$opt" in
x)
;;
y)
Y=$OPTARG
;;
:)
echo "require args"
;;
?)
echo "invalid args"
;;
esac
done
while true
while :
until condition 至少执行一次,和while 条件相反
done 2> error.log 在所有循环体的done 后面可以做标准输出/错误的重定向,while/until循环体的done可后面以做标准输入重定向
select VAR in LIST
do
case EXPR in
PATTERN1)
CONSEQUENT-COMMANDS
;;
PATTERN2 | PATTERN3)
CONSEQUENT-COMMANDS
;;
esac
done
# case 语句可以单独使用
break 用于for/while/until/select
continue 用于for/while/until
$@ argv
$# argc
$* argv to string
$0 script name
$? Last cmd exit code
$$ process ID
$PARAMETER = ${PARAMETER}
${!PARAMETER} 间接参数扩展
${!PREFIX*} = ${!PREFIX@} 变量名扩展
${PARAMETER#PATTERN} 从前向后找,删除最短匹配串
${PARAMETER##PATTERN} 从前向后找,删除最长匹配串
${PARAMETER%PATTERN} 从后向前找,删除最短匹配串
${PARAMETER%%PATTERN} 从后向前找,删除最长匹配串
${PARAMETER/PATTERN/STRING} 查找并替换一处匹配
${PARAMETER//PATTERN/STRING} 查找并替换所有匹配
${PARAMETER/PATTERN} 查找并删除一处匹配
${PARAMETER//PATTERN} 查找并删除所有匹配
${#PARAMETER} 计算字符串长度
${PARAMETER:OFFSET:LENGTH} 获取子串,LENGTH可忽略
myarrary=(value1 value2 valueN) 数组初始化
${myarrary[3]}="new one" 插入数组元素
unset myarrary[3] 删除数组元素
${myarrary[@]} = ${myarrary[*]} 遍历数组元素
myarray=(${STRING}) 将字符串按空格转换成数组
var=$(( EXPR )) 用算术扩展进行整数计算
let EXPR 用let进行算术运算,运算式中不能有空格
expr EXPR 用expr进行算术运算,运算符两边必须用空格,并且只能计算整数
定义1 function func_name { commands }
定义2 func_name() { commands }
函数入参 $1 .. $n
定义函数内部变量 local
函数返回码 return N
函数返回值,函数内最后一条命令的结果
调用 func_name arg1 arg2
调用,接收返回值 ret=$(func_name arg1 arg2)
调用,转入后台 func_name args &
. /path/to/bash/script args
source /path/to/bash/script args
command &> filename
command >& filename
command > filename 2>&1
command 2>&1 > filename
awk -F: '{print $1 $NF}' #显示列
cut -d: -f1,6 #显示列
cut -c 1 #显示第一个字符
grep "string" #显示包含string的行
grep "regex" #显示匹配正则表达式的行
grep -i "string" #显示包含string的行,忽略大小写
grep -v "string" #显示不包含string的行
grep -E "str1|str2" #显示包含str1或者str2的行
head -n 5 #显示前5行
paste -d: file1 file2 #将文件内容横向合并,分隔符为:
paste file1 - - - #将文件内容显示为3列
sed 's/xxx/yyy/g' #将xxx替换为yyy
sed '/xxx/d' #将xxx删除
sed -e cmd1 -e cmd2 #执行多个sed 命令
sed -i cmd #直接修改文件
sort -n #首列按字面数值排列
sort -u #排序后去重
strings #过滤出可打印字符串
tail -n 5 #显示文件最后5行
tee #不影响显示的情况下存储输出到文件
tr 'regex1' 'regex2' #将regex1 转换成regex2
tr -d 'regex' #删除regex匹配到的字符
uniq #删除重复的行
uniq -c #计算重复行数
wc -l #计算行数
^ #锚定行的开始
$ #锚定行的结束
. #匹配一个非换行符的字符
* #匹配零个或多个先前字符
.* #一起用代表任意字符
[] #匹配一个指定范围内的字符。
[^] #匹配一个不在指定范围内的字符
/(/) #标记匹配字符
/< #锚定单词的开始,
/> #锚定单词的结束
/{m,n/} #重复字符m~n次,n可忽略
/w #[A-Za-z0-9]
/W #/w的反置形式
/b #单词锁定符
[[:alnum:]] #[A-Za-z0-9]
[[:alpha:]] #[A-Za-z]
[[:digit:]] #[0-9]
[[:lower:]] #[a-z]
[[:upper:]] #[A-Z]
[[:blank:]] #空字符: 空格键符 和 制表符
[[:space:]] #空格字符: 制表符、换行符、垂直制表符、换页符、回车符和空格键符
awk -F: 'PATTERN { ACTION }'
awk -F: 'BEGIN { ACTION } /pattern1/ { ACTION } /pattern2/ { ACTION } END { ACTION }'
ENVIRON: 环境变量的关联数组 awk 'BEGIN { print ENVIRON["USER"] }'
FILENAME: 当前文件名 awk 'END {print FILENAME}' marks.txt
FS: 输入分隔符 cat marks.txt | awk 'BEGIN {FS='-'} {print $1, $2}'
OFS: 输出分隔符 cat marks.txt | awk 'BEGIN {FS="-"; OFS=":"} {print $1, $2}'
NF: 分隔之后的列数 cat marks.txt | awk 'BEGIN {FS="-"} {print NF}'
NR: 行号 cat marks.txt | awk '{print NF}'
《Linux Shell 命令行及脚本编程实例详解》
原始博客连接: https://editor.csdn.net/md?articleId=127997233