学习笔记第十八天

1.Shell基本语法

1.注释:以#符号开始,直到行末,用于解释代码或暂时禁用某行代码。

2.命令:如echols等,用于执行系统命令或调用外部程序。

3.控制结构:包括if语句、for循环、while循环等,用于控制脚本的流程。

2.创建和执行脚本

1.创建脚本文件:使用文本编辑器(如vim、nano等)创建脚本文件,通常命名为xxx.sh

2.指定解释器:脚本的第一行通常是#!/bin/bash(或其他Shell路径),指定了执行该脚本时

使用的解释器。

3.保存脚本:将编辑好的脚本内容保存至文件中。

4.添加执行权限:通过chmod +x xxx.sh命令给脚本文件添加可执行权限。

5.执行脚本:在脚本文件所在的目录下,通过./xxx.sh命令执行脚本。

3.变量和命令

1.变量定义:变量名=值(注意等号两边不能有空格),如a=0

2.使用变量:通过$变量名来引用变量的值,如echo $a

3.输入

3.1从命令行读取参数:$1$2等,分别代表第一个、第二个参数。

3.2从用户读取输入:使用read命令。

4.输出

4.1echo:用于打印字符串。如果字符串中包含变量,使用$变量名来打印变量的值。

4.2单引号'':里面的内容会被当作普通字符串处理,变量不会被解析。

4.3双引号"":里面的内容会被处理,变量会被解析为其值。

4.4反引号:命令(注意不是单引号),会执行其中的命令并将输出结果替换到当前位置。

4.Shell脚本比较运算符

  • -eq:等于
  • -ne:不等于
  • -gt:大于
  • -lt:小于
  • -ge:大于等于
  • -le:小于等于

5.expr

Shell脚本中可以使用expr命令进行基本的算术运算,但需要注意乘法运算符*expr中需要转义(\*),或者将表达式放在双引号中以避免被Shell解释。

6. if-else 语句

if [ 条件表达式 ]

then

条件为真时执行的命令

else

条件为假时执行的命令

fi

复制代码
#!/bin/bash
if [ $a -eq $b ]
then
    echo "a 等于 b"
else
    echo "a 不等于 b"
fi

7. while 语句

while [ 条件表达式 ]

do

执行的命令

done

复制代码
#!/bin/bash
count=1
while [ $count -le 5 ]
do
    echo "这是第 $count 次循环"
    count=$((count + 1))
done

8. for 语句

for 变量 in 列表

do

执行的命令

done

复制代码
#!/bin/bash
for i in 1 2 3 4 5
do
    echo "这是 $i"
done

9. case 语句

case 变量 in

模式1)

命令...

;;

模式2)

命令...

;;

*)

默认命令

;;

esac

复制代码
read num
case $num in
    1) echo "你选择了 1";;
    2) echo "你选择了 2";;
    *) echo "无效选择";;
esac

10. until 语句

until [ 条件表达式 ]

do

执行的命令

done

复制代码
count=1
until [ $count -gt 5 ]
do
    echo "这是第 $count 次循环"
    count=$((count + 1))
done
相关推荐
淮北4945 小时前
vim学习进阶
学习·编辑器·vim
智者知已应修善业6 小时前
【proteus中lm339电压滞回比较器达到三角波转换成方波】2023-4-13
驱动开发·经验分享·笔记·硬件架构·proteus·硬件工程
551只玄猫6 小时前
新编大学德语1第三版笔记 第5课Essen und Trinken
笔记·学习笔记·德语·外语·德语a1·自学德语·新编大学德语
sayang_shao6 小时前
ARM架构运行模式学习笔记
arm开发·学习·架构
不只会拍照的程序猿7 小时前
《嵌入式AI筑基笔记02:Python数据类型01,从C的“硬核”到Python的“包容”》
人工智能·笔记·python
happymaker06268 小时前
web前端学习日记——DAY04
前端·学习
solicitous9 小时前
遇到一个口头机遇
学习·生活
观书喜夜长11 小时前
大模型应用开发学习-基于 LangChain 框架实现的交互式问答脚本
python·学习
中屹指纹浏览器11 小时前
2026指纹浏览器性能瓶颈分析与优化技巧
经验分享·笔记
FPGA小迷弟11 小时前
FPGA 时序约束基础:从时钟定义到输入输出延迟的完整设置
前端·学习·fpga开发·verilog·fpga