Linux Bible

From Danbing
Jump to navigation Jump to search

Bash

||, &&, <, >, =, ==, =~, -n, -z, -lt, -eq, -ne
<, >, = (字符串比较,双括号不需要转移) [ "${name}" \> "a" -o "${name}" \< "m" ]  [[ "${name}" > "a" && "${name}" < "m" ]]
"t=""abc123""
""$t"" == abc*  true (globabing 比较)
""$t"" == ""abc*""  false (字面比较)
[[ ""$t"" =~ [abc]+[123]+ ]] true (正则表达式比较)
""$t"" =~ ""abc*""  false (字面比较)
r=""a b+""
""a bbb"" =~ $r  true"

Conditon

-d file file存在并且是一个目录
-e file file存在
-f file file存在并且是普通文件
-r file file有读权限
-s file file存在且不为空
-w file file写权限
-x file file有执行权限
-a FILE 如果 FILE 存在则为真。
[ -b FILE ] 如果 FILE 存在且是一个块特殊文件则为真。
[ -c FILE ] 如果 FILE 存在且是一个字特殊文件则为真。
[ -d FILE ] 如果 FILE 存在且是一个目录则为真。
[ -e FILE ] 如果 FILE 存在则为真。
[ -f FILE ] 如果 FILE 存在且是一个普通文件则为真。
[ -g FILE ] 如果 FILE 存在且已经设置了SGID则为真。
[ -h FILE ] 如果 FILE 存在且是一个符号连接则为真。
[ -k FILE ] 如果 FILE 存在且已经设置了粘制位则为真。
[ -p FILE ] 如果 FILE 存在且是一个名字管道(F如果O)则为真。
[ -r FILE ] 如果 FILE 存在且是可读的则为真。
[ -s FILE ] 如果 FILE 存在且大小不为0则为真。
[ -t FD ] 如果文件描述符 FD 打开且指向一个终端则为真。
[ -u FILE ] 如果 FILE 存在且设置了SUID (set user ID)则为真。
[ -w FILE ] 如果 FILE 如果 FILE 存在且是可写的则为真。
[ -x FILE ] 如果 FILE 存在且是可执行的则为真。
[ -O FILE ] 如果 FILE 存在且属有效用户ID则为真。
[ -G FILE ] 如果 FILE 存在且属有效用户组则为真。
[ -L FILE ] 如果 FILE 存在且是一个符号连接则为真。
[ -N FILE ] 如果 FILE 存在 and has been mod如果ied since it was last read则为真。
[ -S FILE ] 如果 FILE 存在且是一个套接字则为真。

Var OP

${#var_name}		$var_name 的字符串长度					
${var:n1}		截取变量var从n1开始的字符					
${var:n1:n2}		截取变量var从n1开始的n2个字符					
${var#substring}	从变量$string的开头, 删除最短匹配$substring的子串					
${var##substring}	从变量$string的开头, 删除最长匹配$substring的子串					
${var#*string}		从左向右截取第一个string后的字符串					
${var##*string}	从左向右截取最后一个string后的字符串					
${var%substring}	从变量$string的结尾, 删除最短匹配$substring的子串 					
${var%%substring}	从变量$string的结尾, 删除最长匹配$substring的子串					
${var%string*}		从右向左截取第一个string后的字符串					
${var%%string*}	从右向左截取最后一个string后的字符串					
${string/substr/rplacemnt}			使用 $rplacemnt, 来代替第一个匹配的 $substr				
${string//substr/rplacemnt}			使用 $rplacemnt, 代替所有匹配的 $substr				
${string/#substr/rplacemnt}			前缀匹配 $substring, 用 $rplacemnt 来代替匹配				
${string/%substr/rplacemnt}			后缀匹配 $substring, 用 $rplacemnt 来代替匹配
${test##*/}  获取文件名
${test%/*}   获取目录名
t_dev=$(cat $i |grep '^dev'|awk '{print $2}')
t_dev=${t_dev//[$'\t\r\n']}
\[\e[F;Bm\]........\[\e[0m\]					
/etc/DIR_COLORS => ~/.dir_colors					
F	B				
30	40	黑色			
31	41	红色			
32	42	绿色			
33	43	黄色			
34	44	蓝色			
35	45	紫红色			
36	46	青蓝色			
37	47	白色			
diff <(wget -o - url1) <(wget -o - url2)

Array

定义:
declare -A array1
declare -a 显示所有数组
赋值:
array1=(value1 value2 value3)
或
array1[0]=value1
array1[1]=value2
变量	取值
echo ${array1[0]}	数组第一个元素
echo ${array1[@]} 或 echo ${array1[*]}	数组所有元素
echo ${#array1[@]}	数组元素个数
echo ${!array1[@]}	数组所有索引下标
echo ${array1[@]:1}	数组索引1以后的元素
echo ${array1[@]:1:2}	数组索引1以后2个元素
declare -a	查看所有普通数组
遍历:
遍历元素
for t in ${allThreads[@]}; do
done
遍历索引
for i in ${!allThreads[@]}; do
done
demo:
统计系统中不同shell的使用次数
declare -A shs
while read line
do
    sh_type=`echo $line | awk -F":" '{print $NF}'`
    let shs[$sh_type]++
done

Loop Array

ls

sed

sed -i "/^<${OP_KEY}>/r ${OP_KFILE}" $conf_file
sed -n '/^-----BEGIN CERTIFICATE-----/,/^-----END CERTIFICATE-----$/p' server.crt
sed -i "/^172.*/s/^172.*$/$netip/" "$xfile"
sed -i "s/dpAclBlacklist/dpAclBlocklist/g" dpMgr/src/dpAclMgr.cpp
sed = a.txt | sed 'N; s/^/     /; s/ *\(.\{4,\}\)\n/\1  /'
sed = a.txt | sed 'N;s/\n/\t/'
sed -n '1,/everyone/p' a.txt
sed -n '/learn/,+2p' a.txt
sed 's/life/leaves/' a.txt
sed 's/to/two/2' a.txt
sed 's/life/learn/g' a.txt
sed 's/to/TWO/2g' a.txt
If you wish to print only the replaced lines, then use “-n” option along with “/p” print flag to display only the replaced lines
sed -n 's/to/TWO/p' a.txt
Replace a pattern with other except in the nth line
sed -i '5!s/life/love/' a.txt
sed -n 's/\(love\)able/\1rs/p'
sed -i '/^status / s/^\(.*\)$/;\1/g' *.conf
cat abc.txt | sed '$G'  #文件尾加空行
echo True | sed 's/[a-z]/\u&/g' - # 转小写
echo True | sed 's/[A-Z]/\l&/g' - # 转大写
echo "abcdefg" | awk '{print toupper($0)}'
echo "ABCDEF" | awk '{print tolower($0)}'
UPPERCASE=(echo(echo VARIABLE | tr '[a-z]' '[A-Z]')
LOWERCASE=(echo(echoVARIABLE | tr '[A-Z]' '[a-z]')
t_dev=$(cat $i |grep '^dev'|awk '{print $2}')
t_dev=${t_dev//[$'\t\r\n']}

awk

ARGC   命令行变元个数 
ARGV   命令行变元数组 
FILENAME   当前输入文件名 
FNR   当前文件中的记录号 
FS   输入域分隔符,默认为一个空格 
RS   输入记录分隔符 
NF   当前记录里域个数 
NR   到目前为止记录数 
OFS   输出域分隔符 
ORS   输出记录分隔符 
计算文件第3列的和
awk '{ x += $3 } END { print x }' myfile.txt
awk -F, 'NF>1 {OFS="%";i=1; while(i<NF) {print $1,$i; i++}}' < input.txt
awk -F, 'BEGIN {print ARGC} NF>1 {OFS="%";i=1; while(i<NF) {print $1,$i; i++}}'
awk '/101/,/105/' file
awk '$1 * $2 >100 ' file
awk '{gsub(/\$/,"");gsub(/,/,""); 
   if ($4>1000&&$4<2000) c1+=$4; 
   else if ($4>2000&&$4<3000) c2+=$4; 
   else if ($4>3000&&$4<4000) c3+=$4; 
   else c4+=$4; } 
   END {printf  "c1=[%d];c2=[%d];c3=[%d];c4=[%d]\n",c1,c2,c3,c4}"'
ls | xargs du -s -m | awk '$1>50000{print $1,$2}'

tar

Tmux Usage

^B + c     New Window
^B + num   Switch to the nubered window
^B + n     Switch to next window
^B + d     Detach the tmux to background
^B + %     Split the window with left/right
^B + "     Split the window with up/down
^B + arrow Switch to window on left/right/up/down
^B + x     Kill current window
^B + z     Enlarge/Recover current window
^B + t     Show clock/time on current window
^B + ,     Rename current window