Maison >Opération et maintenance >exploitation et maintenance Linux >Treize questions classiques sur les scripts Shell
Nous savons que le fonctionnement d'un ordinateur est indissociable du matériel, mais il ne peut pas faire fonctionner directement le matériel. Le pilote du matériel ne peut être contrôlé que par un logiciel appelé « système d'exploitation (OS) à proprement parler. Un système d'exploitation (OS).
Les utilisateurs ne peuvent pas exploiter directement le noyau, mais communiquer avec le noyau via le programme "shell" du noyau, appelé Shell. le système ne peut être utilisé que pour effectuer un travail via la ligne de commande. Par conséquent, la définition la plus simple de Shell est : Interpréteur de commandes (Interpréteur de commandes)
Traduit les commandes de l'utilisateur vers le noyau pour traitement ; En même temps, les résultats du traitement du noyau sont traduits pour l'utilisateur.
Différents systèmes d'exploitation utilisent différents noyaux ; vous pouvez également utiliser différents shells communs, notamment sh, bash et csh. etc Après vous être connecté avec succès à un terminal Shell, la partie à gauche du curseur est appelée l'invite d'invite, qui est généralement utilisée par les utilisateurs ordinaires Invite du Shell : vous pouvez saisir des commandes après avoir tapé la commande. , le CR (Carriage Return) est lu jusqu'à ce que la commande soit saisie des caractères Carriage Return : La commande peut être exécutée Si vous regardez les détails techniques, le Shell décomposera le texte. saisi sur la ligne de commande dans des "champs" basés sur IFS (Internal Field Seperator) "(mot/champ). Ensuite, les caractères spéciaux (méta) sont traités en premier, et enfin toute la ligne de commande est réorganisée. echo envoie l'argument à la sortie standard (stdout), qui est généralement affichée à l'écran entrée standard stdin citation dure : soft quote: 变量定义: 变量替换:2. Quelle est la relation entre l'invite Shell (PS1) et le retour chariot (CR) ?
$
,管理员用户使用#
3. Les autres font écho, et vous faites également écho. Que savez-vous de l'écho
sortie standard stdout
sortie d'erreur standard stderrecho -n # 取消换行符
echo -e # 启用反斜杠转译
4. Quelle est la différence entre les guillemets doubles "" et les guillemets simples '' ?
''
(guillemet simple), fermez toutes les références''
(单引号),关闭所有引用""
(双引号),保留$引用5、var=value? export 前后差在哪?
name=value
,等号左右两边不能使用分隔符。echo ${name}
echo ${name
🎜export变量:export name=value
,使变量成为环境变量
# 本地变量 A=B # 取消变量 unset A # 环境变量export A=B
环境变量只能从父进程到子进程单向传递。换句话说:在子进程中环境如何变更,均不会影响父进程的环境。
当我们执行一个shell script时,其实是先产生一个sub-shell的子进程, 然后sub-shell再去产生命令行的子进程。关注Linux中文社区
# 创建子shell执行脚本 ./1.sh # 当前shell执行 source 1.sh # 当前shell执行后退出 exec 1.sh
( )
将 command group 置于 sub-shell 执行{ }
则是在同一个shell内完成
# 假设我们定义了一个变量为: file=/dir1/dir2/dir3/my.file.txt # 我们可以用 ${ } 分别替换获得不同的值: # 1. shell字符串的非贪婪(最小匹配)左删除 ${file#*/} # 拿掉第一条 / 及其左边的字符串:dir1/dir2/dir3/my.file.txt # 2. shell字符串的贪婪(最大匹配)左删除 ${file##*/} # 拿掉最后一条 / 及其左边的字符串:my.file.txt ${file##*.} # 拿掉最后一个 . 及其左边的字符串:txt # 3. shell字符串的非贪婪(最小匹配)右删除: ${file%/*} # 拿掉最后条 / 及其右边的字符串:/dir1/dir2/dir3 ${file%.*} # 拿掉最后一个 . 及其右边的字符串:/dir1/dir2/dir3/my.file # 4. shell字符串的贪婪(最大匹配)右删除: ${file%%/*} # 拿掉第一条 / 及其右边的字符串:(空值) ${file%%.*} # 拿掉第一个 . 及其右边的字符串:/dir1/dir2/dir3/my 记忆的方法为: # 是去掉左边(在键盘上 # 在 $ 之左边) % 是去掉右边(在键盘上 % 在 $ 之右边) 单一符号是最小匹配﹔两个符号是最大匹配。
# 5. shell字符串取子串: ${file:0:5}:提取最左边的 5 个字节:/dir1 ${file:5:5}:提取第 5 个字节右边的连续 5 个字节:/dir2 # 6. shell字符串变量值的替换: ${file/dir/path}:将第一个 dir 提换为 path:/path1/dir2/dir3/my.file.txt ${file//dir/path}:将全部 dir 提换为 path:/path1/path2/path3/my.file.txt # 7. ${}还可针对变量的不同状态(没设定、空值、非空值)进行赋值: ${file-my.file.txt} :假如 $file 没有设定,则使用 my.file.txt 作传回值。(空值及非空值时不作处理) ${file:-my.file.txt} :假如 $file 没有设定或为空值,则使用 my.file.txt 作传回值。(非空值时不作处理) ${file+my.file.txt} :假如 $file 设为空值或非空值,均使用 my.file.txt 作传回值。(没设定时不作处理) ${file:+my.file.txt} :若 $file 为非空值,则使用 my.file.txt 作传回值。(没设定及空值时不作处理) ${file=my.file.txt} :若 $file 没设定,则使用 my.file.txt 作传回值,同时将 $file 赋值为 my.file.txt 。(空值及非空值时不作处理) ${file:=my.file.txt} :若 $file 没设定或为空值,则使用 my.file.txt 作传回值,同时将 $file 赋值为 my.file.txt 。(非空值时不作处理) ${file?my.file.txt} :若 $file 没设定,则将 my.file.txt 输出至 STDERR。(空值及非空值时不作处理) ${file:?my.file.txt} :若 $file 没设定或为空值,则将 my.file.txt 输出至 STDERR。(非空值时不作处理) tips: 以上的理解在于, 你一定要分清楚 unset 与 null 及 non-null 这三种赋值状态. 一般而言, : 与 null 有关, 若不带 : 的话, null 不受影响, 若带 : 则连 null 也受影响.
# 8. 计算shell字符串变量的长度:${#var} ${#var} 可计算出变量值的长度: ${#file} 可得到 27 ,因为 /dir1/dir2/dir3/my.file.txt 刚好是 27 个字节... # 9. bash数组(array)的处理方法 数组: A=(a b c d) 引用数组: ${A[@]} ${A[*]} 访问数组成员 ${A[0]} 计算数组长度 ${#A[@]} ${#A[*]} 数组重新赋值 A[2]=xyz # 10.$(( ))是用来做整数运算的 a=5;b=7;c=2; echo $(( a + b * c))
"$@"
则可得到 “p1” “p2 p3” “p4” 这三个不同的词段
"$*"
Vous pouvez obtenir toute une série de phrases simples comme "p1 p2 p3 p4"
De plus, effectuez une recherche sur le compte public Linux pour savoir comment répondre "git books" en arrière-plan et obtenez un paquet cadeau surprise .
1. La commande test a deux formes
expression de test
[ expression ]
2.
chaîne : chaîneentier : entier
fichier : fichier
3、当 expression 为真是返回 0(true) ,否则返回 非0(false)
command1 && command2 command2 只有在 command1 的RV为0(True)的条件下执行。
command1 || command2 command2只有在command1的RV为非0(False)的条件下执行。
4、先替换变量再比较
A=123[ -n "$A" ] && ([ "$A" -lt 100 ] || echo "too big")unset A
ls my.file no.such.file 1> file.out 2>file.err # 2>&1 就是将stderr并进stdout做输出 ls my.file no.such.file 1> file.out 2>&1 # /dev/null 空 ls my.file no.such.file >/dev/null 2>&1 cat < file > file # 在 IO Redirection 中,stdout 与 stderr 的管道会先准备好,才会从 stdin 读进资料。 # 也就是说,在上例中,> file 会先将 file 清空,然后才读进 < file , # 但这时候档案已经被清空了,因此就变成读不进任何数据了
# if echo -n "Do you want to continue?(Yes/No):" read YN if [ "$YN"=Y -o "$YN"=y -o "$YN"="Yes" -o "$YN"="yes" -o "$YN"="YES"];then echo "continue" else exit 0 fi # case echo -n "Do you want to continue?(Yes/No):" read YN case "$YN" in [Yy]|[Yy][Ee][Ss]) echo "continue" ;; *) exit 0 esac
# for for ((i=1;i<=10;i++)) do echo "num is $i" done # while num=1 while [ "$num" -le 10 ]; do echo "num is $num" num=$(($num + 1)) done # until num=1 until [ "$num" -gt 10 ]; do echo "num is $num" num=$(($nu + 1)) done
break 是结束 loop
return 是结束 function
exit 是结束 script/shell
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!