Shell脚本编程规范与变量

文章介绍了Shell脚本的基本构成,包括脚本声明(解释器)、注释、可执行语句。讲解了如何执行脚本,如使用./、source等命令,并阐述了管道操作和重定向输入输出。此外,还详细讨论了Shell脚本中的标准输入、输出和错误,以及重定向操作。文中提到了变量的使用,包括自定义变量、环境变量、位置变量和预定义变量,以及变量的赋值、只读变量和引用规则。
摘要由CSDN通过智能技术生成

1. shell 脚本的构成
1.脚本申明(解释器):若第一行为“#!/bin/bash”,表示此行以下的代码语句是通过/bin/bash程序来解释执行,
#!/bin/bash为默认解释器。还有其它类型的解释器,比如#!/usr/bin/python、#!/usr/bin/expect。

2.注释信息:以“#”开头的语句表示为注释信息,被注释的语句在运行脚本时不会被执行。

3.可执行语句:比如echo命令,用于输出" "之间的字符串

# This is my first Shell-Script.

vim lu.sh
 

 

 

执行文件脚本的命令

主流   ./lu.sh  但需要赋予权限 chmod 777 lu.sh

source lu.sh  

sh lu.sh

bash lu.sh

管道操作  |
将管道符号“|”左侧的命令输出的结果,作为右侧命令的输入(处理对象),同一行命令中可以使用多个管道。
ps aux | wc -l
echo "abc123" | passwd --stdin zhangsan

重定向
交互式硬件设备
类型                设备文件        文件描述编号        默认设备
标准输入            /dev/stdin        0                    键盘
标准输出            /dev/stdout        1                    显示器
标准错误输出        /dev/stderr        2                    显示器

标准输入(STDIN):默认的设备是键盘,文件编号为 0,命令将从标准输入文件中读取在执行过程中需要的输入数据。

标准输出(STDOUT):默认的设备是显示器,文件编号为 1,命令将执行后的输出结果发送到标准输出文件。

标准错误(STDERR):默认的设备是显示器,文件编号为 2,命令将执行期间的各种错误信息发送到标准错误文件

重定向操作
类型            操作符        用途
重定向输入        <            从指定的文件读取数据
重定向输出        >            将标准输出结果 保存 到指定的文件,并且覆盖原有内容
                >>            将标准输出结果 追加 到指定的文件的尾部,不覆盖原有内容
重定向错误输出    2>            将错误信息 保存 到指定的文件,并且覆盖原有内容
                2>>            将错误信息 追加 到指定的文件的尾部,不覆盖原有内容
混合输出        &>            将标准输出、标准错误保存到同一文件中
                2>&1        将标准错误输出重定向到标准输出

echo "123456" > pass.txt
passwd --stdin zhangsan < pass.txt
#从 pass.txt 文件中取密码,需要注意 SELinux 会影响此命令执行,若执行失败可尝试关闭 SELinux
 


bash -n 脚本名称 (不在当前目录下加绝对路径)     检查语法错误
bash -x 脚本名称 (不在当前目录下加绝对路径)     逻辑错误


变量的作用:用来存放系统和用户需要使用的特定参数(值)
变量名:使用固定的名称,由系统预设或用户定义
变量值:能够根据用户设置、系统环境的变化而变化

变量的分类
自定义变量:由用户自己定义、修改和使用
环境变量:由系统维护,用于设置工作环境
位置变量:通过命令行给脚本程序传递参数
预定义变量:Bash中内置的一类变量,不能直接修改

定义新的变量
格式:变量名=变量值
变量命名规则:以字母或下划线开头,区分大小写
product=benet
version=6.0
name="zhang san"

查看变量的值
格式:echo $变量名
echo $product
echo $product $version
echo ${product}40
${}是一种特殊的语法形式,用于获取变量的值或者对变量进行操作。
${}语法可以应用于任何变量名称,其中变量名称放在花括号中,例如${product},其中VAR是变量名。
 

readonly 命令设置只读变量
product=benet
readonly product                    #设置为只读变量
echo $product
product=accp                        #只读变量不可以被重新赋值
unset product                        #只读变量不可以被删除,unset 命令用于删除变量
 

赋值时使用引号
双引号:允许通过$符号引用其他变量值
单引号:禁止引用其他变量值,$视为普通字符
反撇号:命令替换,提取命令执行后的输出结果,`…`和$(…)作用相同
a=`ps -ef | grep sshd`
echo $a
root 1121 1 0 09:29 ? 00:00:00 /usr/sbin/sshd -D root 2165 1121 0 09:31 ? 
00:00:00 sshd: root@pts/0 root 2247 2245 0 09:34 pts/0 00:00:00 grep --color=auto sshd

弱引用和强引用
"$name " 弱引用,其中的变量引用会被替换为变量值
'$name ' 强引用,其中的变量引用不会被替换为变量值,而保持原字符串
 

read命令获取输入内容
-p prompt:指定提示符,用于提示用户输入数据。
-a array:将输入数据存储到一个数组中。

方法一:
read -p "提示信息" 变量名
echo $变量名

方法二:
echo -n "提示信息"
read 变量名
echo $变量名

read -a 

数组输入

#!/bin/bash

echo "请输入一个单词: "
read -a words

echo "输入的第一个单词是: ${words[0]}"
echo "输入的第二个单词是: ${words[1]}"
echo "输入的第三个单词是: ${words[2]}"

[root@localhost ~]# sh test1.sh 
请输入一个单词: 
123 456 789
输入的第一个单词是: 123
输入的第二个单词是: 456
输入的第三个单词是: 789
 


变量作用范围
默认情况下,新定义的变量只在当前的Shell环境中有效,因此称为局部变量。当进入子程序或新的子Shell环境时,局部变量将无法再使用。
可以通过内部命令export将指定的变量导出为全局变量,使用户定义的变量在所有的子Shell环境中能够继续使用。
格式1:export 变量名
格式2:export 变量名=变量值
[root@localhost ~]# export dn
[root@localhost ~]# dn=1
[root@localhost ~]# export dxl
[root@localhost ~]# dxl=2
[root@localhost ~]# vim 123.sh
echo $(($dn+$dxl))
[root@localhost ~]# sh 123.sh 
3


环境变量
环境变量由系统提前创建,用来设置用户的工作环境
使用 env 命令可以查看到当前工作环境下的环境变量
变量USER表示用户名称,HOME表示用户的宿主目录,LANG表示语言和字符集,PWD表示当前所在的工作目录,
变量PATH表示可执行程序的默认搜索路径

$USER 表示用户名称

$HOME 表示用户的宿主目录

$LANG 表示语言和字符集

$PWD 表示当前所在工作目录

$PATH 表示可执行用户程序的默认路径

echo $PATH                    #查看当前搜索路径
PATH="$PATH:/root"            #将/root目录添加到搜索路径
export PATH="$PATH:/root"    #输出为全局环境变量
[root@localhost ~]# chmod 777 123.sh #给执行权限
[root@localhost ~]# 123.sh   #可以直接打印
3


环境变量的全局配置文件为/etc/profile,在此文件中定义的变量作用于所有用户。
每个用户还有自己的独立配置文件(~/.bash_profile)。可以用来长期变更或设置某个环境变量。
vim /root/.bash_profile
export HISTSIZE=200                    #修改root用户的历史命令记录条数

echo $HISTSIZE
source /root/.bash_profile            #读取并执行文件中的设置
echo $HISTSIZE
这个profile里面声名两个全局变量,直接在脚本中引用

位置变量
当执行命令行操作时,第一个字段表示命令名或脚本程序名,其余的字符串参数按照从左到右的顺序依次赋值给位置变量。
$n:n为数字,$0代表命令本身,$1-$9代表带一个到第九个参数,十以上的参数需要使用大括号表示,比如第十个参数为${10}

vim addnum.sh
num1=$1
num2=$2
sum=$(($num1 + $num2))
echo $sum

./addnum.sh 12 34
    $0        $1 $2


预定义变量
$*、$@:表示命令或脚本要处理的参数。
  "$*":把所有参数看成以空格分隔的一个字符串整体(单字符串)返回,代表"$1 $2 $3 $4"。
  "$@":把各个参数加上双引号分隔成n份的参数列表,每个参数作为一个字符串返回,代表"$1" "$2" "$3" "$4"。

$0:表示当前执行的脚本或命令的名称。
$#:表示命令或脚本要处理的参数的个数。    
$?:表示前一条命令或脚本执行后的返回状态码,返回值为0表示执行正确,返回任何非0值均表示执行出现异常。也常被用于Shell脚本中return退出函数并返回的退出值。

$*加引号
vim test.sh
#!/bin/bash

function print_args {
  for arg in "$*"; do
    echo "$arg"
  done
}

print_args "Hello" "World" "!"
函数将只输出一个字符串“Hello World !”。


$*不加引号
#!/bin/bash

function print_args {
  for arg in $*; do
    echo "$arg"
  done
}

print_args "Hello" "World" "!"
函数将分别输出三个字符串“Hello”、“World”和“!”


$*、$@不加双引号时表现一致;加双引号时,$*会将所有参数作为一个整体。
#!/bin/bash

function print_args_star {
  for arg in "$*"; do
    echo "$arg"
  done
}

function print_args_at {
  for arg in "$@"; do
    echo "$arg"
  done
}

print_args_star "Hello" "World" "!"
echo "--------"
print_args_at "Hello" "World" "!"


$#---$#是一个特殊的全局变量,它表示传递给当前脚本或函数的参数个数。
[root@localhost ~]# vim test.sh
#!/bin/bash

echo "输入的对象数为: $#"

[root@localhost ~]# sh test.sh 1 2 3 4 5 6
输入的对象数为: 6


$?:表示前一条命令或脚本执行后的返回状态码,返回值为0表示执行正确,
返回任何非0值均表示执行出现异常。也常被用于Shell脚本中return退出函数并返回的退出值。
vim test.sh
read -p "请输入第一个比较的数据:" a
read -p "请输入第二个比较的数据:" b
if [ $a == $b ]
then
echo "right"
else
echo $?
fi


不使用特殊的字符串

不适用中文名

区分大小写

echo $a   查看的意思

 

 

""   强引用 ,引用变量名时还是

' '   弱引用    

``

三种引号的不一样

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值