0


Linux-3:Shell编程——基础语法(0-50%)

前言

  • Shell是一种程序设计语言。作为命令语言,它交互式解释和执行用户输入的命令或者自动地解释和执行预先设定好的一连串的命令;作为程序设计语言,它定义了各种变量和参数,并提供了许多在高级语言中才具有的控制结构,包括循环和分支。
  • Shell 是一个用 C 语言编写的程序,它是用户使用 Linux 的桥梁。
  • Shell 既是一种命令语言,又是一种程序设计语言。

一、变量

1.定义变量

  • Shell 支持以下三种定义变量的方式 - variable=value- variable='value'- variable="value"

注意!!!赋值号=的周围不能有空格,这可能和你熟悉的大部分编程语言都不一样。

运行文件之前记得保存 ctrl + s 快捷保存

  • Shell 变量的命名规范和大部分编程语言都一样: - 变量名由数字、字母、下划线组成;- 必须以字母或者下划线开头;- 不能使用 Shell 里的关键字(通过 help 命令可以查看保留关键字)。

举例:.sh文件的开头必须是 #!/bin/sh 或者 #!/bin/bash 这是为了告诉操作系统使用该解释器

  1. #!/bin/sh
  2. a="hello world"
  3. b=helloworld
  4. c='hello world'

2.使用变量

  • 使用一个定义过的变量,只要在变量名前面加美元符号$即可
  • 变量名外面的花括号{ }是可选的,加不加都行,加花括号是为了帮助解释器识别变量的边界
  • 当变量与其他字符相连时,应使用花括号
  1. #!/bin/sh
  2. a="java"
  3. echo $a # echo 打印 相当于python里的print
  4. echo ${a}
  5. echo "Can you use ${a}web"

3.修改变量

  • 已定义的变量,可以被重新赋值
  1. #!/bin/bash
  2. $b='java'
  3. b='java' # 正确更改变量 直接 变量名=新值
  4. echo "${b} is good"
  • 单引号和双引号的区别
  1. #!/bin/bash
  2. # 单双引号的区别 单引号内任何符号都被识别为字符串 无法引用变量
  3. # 引用变量时最好加个{} 提高代码可读性
  4. echo "hhhh ${b}"
  5. echo 'hhhh ${b}'
  6. echo hhhh ${b}

输出: 单引号引起来的全部被识别为字符串输出

  1. hhhh
  2. hhhh ${b}
  3. hhhh

4.将命令的结果赋值给变量

  • vm里有不少命令都会输出结果
  • 可以将结果赋值给变量进行使用
  1. #!/bin/bash
  2. # 命令的使用
  3. comm=$(ps) # ps 查看当前存在的进程及其状态 通过$()将命令进行赋值
  4. echo ${comm}
  5. echo "there is : $(pwd)" # pwd 查看当前文件路径
  6. echo "there is : `pwd`" # 优先运行$()和``里的命令 将结果作为参数输出

输出:

  1. PID TTY TIME CMD 3450 pts/1 00:00:00 bash 4014 pts/1 00:00:00 sh 4015 pts/1 00:00:00 ps
  2. there is : /root/shell_code
  3. there is : /root/shell_code

5.只读变量

  • 使用 readonly 命令 将变量定义为只读变量
  • 只读变量不可修改或删除
  1. #!/bin/bash
  2. # readonly 只读变量 不能修改 也不能被删除
  3. tt="abcd"
  4. echo "${tt}...."
  5. readonly tt # 将tt变成只读变量
  6. tt="lsakdjflkj" # 赋值不成功 行31: tt: 只读变量
  7. echo "${tt}...."

输出:

  1. abcd....
  2. demo2.sh:行40: tt: 只读变量 # 因为尝试修改只读变量 所以报错

6.删除变量

  • 使用 unset 命令删除变量
  • 变量被删除后不能再次使用
  • unset 命令不能删除只读变量
  1. #!/bin/sh
  2. tt="abcd"
  3. readonly tt # 将tt变成只读变量
  4. # unset 删除变量
  5. unset tt # 删除tt变量 第 34 行:unset: tt: 无法反设定: 只读 variable
  6. echo "${tt}.lsjdfl"
  7. b="python"
  8. echo "${b} is good"
  9. unset b
  10. echo "${b} is good" # b变量被删除 但是引用不会报错 只是输出空

输出:尝试删除只读变量 tt 会报错 ;删除失败 tt 仍可以使用;普通变量 b 被删除后引用不会报错 只是输出空

  1. demo2.sh: 47 行:unset: tt: 无法反设定: 只读 variable
  2. abcd.lsjdfl
  3. python is good
  4. is good

二、传递参数

举例:

  1. #!/bin/sh
  2. # Shell脚本 脚本传参
  3. echo "运行的文件名为:$0" # 这个脚本本身是第0个参数
  4. echo "传递的第1个参数为:$1 "
  5. echo "传递的第2个参数为:$2 "
  6. echo "传递的第3个参数为:$3 "
  7. echo "传递的第4个参数为:$4 "
  8. echo "传递的第5个参数为:$5 "
  9. echo "传递的第6个参数为:$6 "
  10. echo "传递的第7个参数为:$7 "
  11. echo "传递的第8个参数为:$8 "
  12. echo "传递的第9个参数为:$9 "
  13. echo "传递的第10个参数为:${10} "
  14. echo "传递的第11个参数为:${11} "
  15. # 假设在脚本运行时写了三个参数 1、2、3
  16. echo "$*" # 则 " * " 等价于 "1 2 3"(传递了一个参数)
  17. echo "$@" # 而 "@" 等价于 "1" "2" "3"(传递了三个参数)
  18. echo $# # $# 统计传入参数的总数 脚本名称是第0个参数

输出:

  1. [root@tokyo001 shell_code]# sh demo3.sh 1 2 3 4 5 65 6 7 8 8 9
  2. 运行的文件名为:demo3.sh
  3. 传递的第1个参数为:1
  4. 传递的第2个参数为:2
  5. 传递的第3个参数为:3
  6. 传递的第4个参数为:4
  7. 传递的第5个参数为:5
  8. 传递的第6个参数为:65
  9. 传递的第7个参数为:6
  10. 传递的第8个参数为:7
  11. 传递的第9个参数为:8
  12. 传递的第10个参数为:8
  13. 传递的第11个参数为:9
  14. 1 2 3 4 5 65 6 7 8 8 9
  15. 1 2 3 4 5 65 6 7 8 8 9
  16. 11

参数处理说明:一般只用 $# $@ $*

三、字符串

1.字符串举例

  1. #!/bin/sh
  2. n=74
  3. str1=www.aaa.com${n}
  4. str2="shell \"script\" ${n}" # 这里的"被\转义
  5. str3='shell "script" $n' # 单引号之内只存在字符串
  6. echo $n
  7. echo $str1
  8. echo $str2
  9. echo $str3

输出:可以看到单引号引起来的${n} 没有被引用变量,而是直接输出,说明单引号引起来的内容只会被认定成字符串输出。

  1. 74
  2. www.aaa.com74
  3. shell "script" 74
  4. shell "script" $n

2.统计字符串长度

  1. #!/bin/sh
  2. n=74
  3. str1=www.aaa.com${n}
  4. str2="shell \"script\" ${n}" # 这里的"被\转义
  5. str3='shell "script" $n' # 单引号之内只存在字符串
  6. #统计字符串中字符的个数
  7. echo ${#n}
  8. echo ${#str3} # 单引号中空格和符号也算
  9. echo ${#str1} # 双引号中空格和符号都不算

输出:注意第二行与第三行的区别

  1. 2
  2. 17
  3. 13

3.字符串拼接

  1. #!/bin/sh
  2. # 字符串的拼接
  3. shell='shell'
  4. url='www.baidu.com'
  5. s1=${shell}${url}
  6. # 两个变量之间加空格 需要用引号引起来
  7. s2=${shell} ${url} # 会报错
  8. s3="${shell} ${url}"
  9. s4=${shell}":"${url}
  10. s5=${shell}:${url}
  11. echo $s1
  12. echo $s2
  13. echo $s3
  14. echo $s4
  15. echo $s5

输出:注意空格的输出,两个变量之间加空格,需要用引号引起来,否则会报错。

  1. demo4.sh:行28: www.baidu.com: 未找到命令
  2. shellwww.baidu.com
  3. shell www.baidu.com
  4. shell:www.baidu.com
  5. shell:www.baidu.com

4.截取字符串

  1. #!/bin/sh
  2. # 截取字符串
  3. url='https://blog.csdn.net/zhangfei5354/article/details/136298293'
  4. # 从指定位置开始截取 ${string:start:length} 无法间隔着截取
  5. echo ${url:0:10}
  6. echo ${url:1} # 从起始位置开始截取全部
  7. echo ${url:20:50} # 截取范围超过最大长度时 截取完就结束
  8. echo ${url:0-5:10} # 从右边开始截取 但方向还是从左往右
  9. echo "----------------------------"
  10. # 从指定字符开始截取 ${string#*chars} 截取右边的字符
  11. echo ${url#*blog} # 截取blog后面的内容
  12. echo ${url#*/} # 匹配第一个遇到的/
  13. echo ${url##*/} # 匹配最后一个/ 在这个字符串里也可以使用s/去精准匹配
  14. echo "----------------------------"
  15. # 截取左边的字符 ${string%chars*}
  16. echo ${url%zhangfei*}
  17. echo ${url%a*} # 匹配最右边的a左边的内容
  18. echo ${url%%a*} # 匹配最左边的子串

输出:注意不同起始位置截取时写法的不同,以及截取左右方向的选择。

  1. https://bl
  2. ttps://blog.csdn.net/zhangfei5354/article/details/136298293
  3. t/zhangfei5354/article/details/136298293
  4. 98293
  5. ----------------------------
  6. .csdn.net/zhangfei5354/article/details/136298293
  7. /blog.csdn.net/zhangfei5354/article/details/136298293
  8. 136298293
  9. ----------------------------
  10. https://blog.csdn.net/
  11. https://blog.csdn.net/zhangfei5354/article/det
  12. https://blog.csdn.net/zh

截取操作汇总:

总结

Shell编程与python大同小异,与python对照着学习更容易理解。

标签: linux ssh

本文转载自: https://blog.csdn.net/weixin_65047977/article/details/140834851
版权归原作者 吃什么芹菜卷 所有, 如有侵权,请联系我们删除。

“Linux-3:Shell编程——基础语法(0-50%)”的评论:

还没有评论