Bash Shell脚本中的数组使用实例

数组是一个包含多个值的变量,这些值可以是相同类型或不同类型。没有数组大小限制,也没有要求成员变量被连续索引或连续分配的限制。数组索引从0开始。

1.声明一个数组并赋值

在bash中,使用以下格式的变量时会自动创建数组:

name[index]=value
  • name 是数组的名字。
  • index 可以是任何数字或表达式,值必须等于或大于零。

要访问数组元素,请使用大括号,例如${name[index]}。下面是访问Unix数组中的第二个元素,以为数组索引从0开始,所以Unix[1]就是第二个元素了。

[root@localhost ~]# cat arraymanip.sh
#! /bin/bash
Unix[0]='Debian'
Unix[1]='Red hat'
Unix[2]='Ubuntu'
Unix[3]='Suse'

echo ${Unix[1]}

执行脚本,以下是输出内容:

[root@localhost ~]# ./arraymain.sh 
Red hat

2.在声明期间初始化数组

不必单独初始化数组的每个元素,可以通过使用括号指定元素列表(由空格分隔)来声明和初始化数组。下面是语法:

declare -a arrayname=(element1 element2 element3)

如果元素具有空格字符,需要使用引号:

[root@localhost ~]# cat arraymain2.sh 

#! /bin/bash
declare -a Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora')

echo ${Unix[4]}

下面是输出结果:

[root@localhost ~]# ./arraymain2.sh 
Fedora


declare -a声明一个数组,括号中的所有元素都是数组的元素。

3.打印整个数组

有多种方法可以打印整个数组。如果索引号是 @ 或者 * ,则引用数组的所有成员。可以使用bash shell中的循环语句遍历数组元素并进行打印。

[root@localhost ~]# cat arraymain.sh 
#! /bin/bash
Unix[0]='Debian'
Unix[1]='Red hat'
Unix[2]='Ubuntu'
Unix[3]='Suse'

echo ${Unix[@]}

下面是输出结果:

[root@localhost ~]# ./arraymain.sh 
Debian Red hat Ubuntu Suse

4.获取数组的长度

可以使用$和#的特殊参数来获取数组的长度。${#arrayname[@]} 可以获取数组长度。

[root@localhost ~]# cat arraymain2.sh 
#! /bin/bash
declare -a Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora')

echo ${#Unix[@]} #数组中元素的数量
echo ${#Unix}  #数组中第一个元素的字符数。

下面是输出,可以看到第一行输出参数为5个。第二行输出第一个元素的字符数量是6个。

[root@localhost ~]# ./arraymain2.sh 
5
6

5.数组中某个元素的长度

${#arrayname[n]} 给出数组中的n个元素的长度。

[root@localhost ~]# cat arraymain.sh 
#! /bin/bash
Unix[0]='Debian'
Unix[1]='Red hat'
Unix[2]='Ubuntu'
Unix[3]='Suse'

echo ${#Unix[3]} #位于索引3的元素的长度。

以下是输出,可以看到输出index为3的值为"Suse"的字符长度是4。

[root@localhost ~]# ./arraymain.sh 
4

6.按数组的偏移量和长度提取

下面的示例显示了从名为Unix的数组中从索引位置3开始提取2个元素的方法。

[root@localhost ~]# cat arraymain.sh 
#! /bin/bash
Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora' 'UTS' 'OpenLinux')
echo ${Unix[@]:3:2}

以下是输出,

[root@localhost ~]# ./arraymain.sh 
Suse Fedora


上面的示例返回第三、第四个索引的值。索引始终以零开头。

7.对于数组的特定元素,使用offset和length提取

从数组元素中仅提取前四个元素。例如,获取数组中的第二个元素,并且获取这个元素的前三个字符:

[root@localhost ~]# cat arraymain.sh 
#! /bin/bash
Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora' 'UTS' 'OpenLinux')

echo ${Unix[1]:0:3}

以下是输出:

[root@localhost ~]# ./arraymain.sh 
Red

8.搜索并替换数组元素

下面的示例在数组中搜索Ubuntu,并将其替换为单词“FreeBSD”。

[root@localhost ~]# cat arraymain.sh 
#! /bin/bash
Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora' 'UTS' 'OpenLinux')

echo ${Unix[@]/Ubuntu/FreeBSD}

以下是输出:

[root@localhost ~]# ./arraymain.sh 
Debian Red hat FreeBSD Suse Fedora UTS OpenLinux
[root@localhost ~]# 


注意,该数组替换,不会写入到数组里面。

9.向现有的数组添加元素

以下示例显示了将元素添加到现有数组的方法。

[root@localhost ~]# cat arraymain.sh 
#! /bin/bash
Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora' 'UTS' 'OpenLinux')
Unix=("${Unix[@]}" "AIX" "HP-UX")

echo ${Unix[@]}

以下是输出:

[root@localhost ~]# ./arraymain.sh 
Debian Red hat Ubuntu Suse Fedora UTS OpenLinux AIX HP-UX


在名为Unix的数组中,元素“ AIX”和“ HP-UX”分别添加在第7个索引和第8个索引中。并输出所有数组元素。

10.从数组中删除一个元素

unset用于从数组中删除元素。unset和分配给元素“Null"值具有相同的效果。

[root@localhost ~]# cat arraymain.sh 
#! /bin/bash
Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora' 'UTS' 'OpenLinux')

unset Unix[1]

echo ${Unix[@]}
echo ${Unix[1]}

以下为输出:

[root@localhost ~]# ./arraymain.sh 
Debian Ubuntu Suse Fedora UTS OpenLinux

上面的脚本将打印整个数组,还有索引为"1"的值,索引为“1”的值是null。


以下示例显示了从数组中完全删除元素的一种方法,下面还是删除索引为1的元素。

[root@localhost ~]# cat arraymain.sh 
#! /bin/bash
Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora' 'UTS' 'OpenLinux')
pos=1
Unix=(${Unix[@]:0:$pos} ${Unix[@]:$(($pos + 1))})
echo ${Unix[@]}

以下为输出:

[root@localhost ~]# ./arraymain.sh 
Debian Ubuntu Suse Fedora UTS OpenLinux


在此示例中,${Unix[@]:0:$pos}值获取第1个索引的元素,,而${Unix[@]:$(($pos + 1))}将从第3个索引到最后一个索引。并合并以上两个输出。这是从数组中删除元素的解决方法之一。

11.使用正则表达式删除数组中的元素

在搜索条件中,可以给出正则表达式,并将剩余的元素存储到另一个数组中,如下所示。

[root@localhost ~]# cat arraymain2.sh 
#! /bin/bash
declare -a Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora')
declare -a pattern=( ${Unix[@]/Red*/} )
echo ${pattern[@]}

以下为输出:

[root@localhost ~]# ./arraymain2.sh 
Debian Ubuntu Suse Fedora


上面的示例中删除了包含"Red"字符的元素。实际是将"Red*"替换为空字符。

12.复制数组

以下实例是将Unix数组复制到Linux数组中:

[root@localhost ~]# cat arraymain.sh 
#!/bin/bash
Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora' 'UTS' 'OpenLinux')
Linux=("${Unix[@]}")

echo ${Linux[@]}

以下为输出:

[root@localhost ~]# ./arraymain.sh 
Debian Red hat Ubuntu Suse Fedora UTS OpenLinux

13.两个数组的关联

展开两个数组的元素,然后将其分配给新数组:

[root@localhost ~]# cat arraymain.sh 
#!/bin/bash
Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora' 'UTS' 'OpenLinux');
Shell=('bash' 'csh' 'jsh' 'rsh' 'ksh' 'rc' 'tcsh');

UnixShell=("${Unix[@]}" "${Shell[@]}")
echo ${UnixShell[@]}
echo ${#UnixShell[@]}

以下为输出:

[root@localhost ~]# ./arraymain.sh 
Debian Red hat Ubuntu Suse Fedora UTS OpenLinux bash csh jsh rsh ksh rc tcsh
14


该实例同时打印数组“ Unix”和“ Shell”数组的元素,并且新数组的元素数为14个。

14.删除整个数组

unset用于删除整个数组。

[root@localhost ~]# cat arraymain.sh 
#!/bin/bash
Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora' 'UTS' 'OpenLinux');
Shell=('bash' 'csh' 'jsh' 'rsh' 'ksh' 'rc' 'tcsh');

UnixShell=("${Unix[@]}" "${Shell[@]}")

unset UnixShell
echo ${#UnixShell[@]}

以下为输出:

[root@localhost ~]# ./arraymain.sh 
0


unset数组之后,其长度将为零,如上所示。

15.将文件内容加载到数组中

您可以将文件内容逐行加载到数组中。

[root@localhost ~]# cat loadcontent.sh 
#!/bin/bash
file=(`cat ./pic.txt`)

for i in "${file[@]}"
do
echo $i
done

echo -e "\033[31m Read file content! \033[0m"

以下为输出:

[root@localhost ~]# ./loadcontent.sh 
https://www.linuxprobe.com/wp-content/uploads/2021/01/windows7.png
https://www.linuxprobe.com/wp-content/uploads/2016/12/bigdata.jpg
https://www.linuxprobe.com/wp-content/uploads/2021/01/write-games-and-learn-python.jpg
https://www.linuxprobe.com/wp-content/uploads/2021/01/data-center-inspection.jpg
https://www.linuxprobe.com/wp-content/uploads/2020/03/devolop-like-linux-09.jpg
 Read file content! 


在上面的示例中,使用for循环,逐一显示文件中每行的内容。

总结

数组是一个包含多个值的变量,这些值可以是相同类型或不同类型。没有数组大小限制,也没有要求成员变量被连续索引或连续分配的限制。数组索引从0开始。

本文原创地址:Bash Shell脚本中的数组使用实例 | 《Linux就该这么学》

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 《bash shell脚本编程经典实例》是一本介绍bash shell脚本编程的经典实例书籍。书详细介绍了bash shell脚本的基础知识和高级应用,包括变量、条件语句、循环语句、函数、文件操作、正则表达式等内容。书还提供了大量实例,让读者通过实践掌握bash shell脚本编程的技巧和方法。这本书对于想要学习bash shell脚本编程的人来说是一本非常好的参考书籍。 ### 回答2: Bash shell是一种常用的Unix/Linux操作系统下的命令行解释器,它提供了非常强大和高效的编程功能。Bash shell脚本编程是一种简单、快速、高效的编程方式,可以用于自动化Unix/Linux系统管理任务、解决日常工作的复杂问题、管理大型项目等。 在实际应用,我们可以应用 Bash shell脚本编写各种应用程序和脚本,例如网站服务器的自动部署、数据备份和还原、自动化软件更新、批量处理大量数据等。以下是一些bash shell脚本编程经典实例: 1.自动化备份脚本使用bash shell脚本编写自动化备份脚本,可以定时备份数据库、网站程序和重要文件,保证数据安全。 2.监控系统运行情况:使用bash shell脚本编写系统的监控工具,可以实时监控系统的各项指标,如CPU、内存和磁盘空间等,确保系统平稳运行。 3.自动化软件更新:使用bash shell脚本编写自动化软件更新脚本,可以自动更新软件并降低管理员的工作量。 4.监控网络服务:使用bash shell脚本编写网络服务监控程序,实时检测网络服务是否可用,减少系统故障发生的可能性。 5.批量数据处理:使用bash shell脚本编写数据处理程序,可以实现批量转换文件格式、删除指定目录下的所有空文件夹等,提高工作效率。 6.自动化部署:使用bash shell脚本编写自动化部署程序,可以自动化地部署应用程序,减少人工干预,降低出错率。 总之,bash shell脚本编程是Unix/Linux系统下非常实用且高效的编程方式,便于操作系统的管理和维护,也可以应用于程序开发和运维等方面,可谓是编程人员的必备技能之一。 ### 回答3: Bash shell脚本编程经典实例是一本非常有价值的书籍。它提供了各种实用的bash shell脚本编程案例,可以帮助读者更高效地完成日常工作。 这本书提供了许多实用的案例,从最基本的脚本语法开始,逐步引导读者掌握bash shell脚本编程。这些案例包括shell脚本编程的基础知识、文件系统管理、系统管理、网络管理、文本处理、进程管理、日志处理等方面。 这本书不仅仅是一个例子的集合,它还教会了读者基本的编程技巧和方法,帮助读者了解如何有效地使用shell脚本编程完成复杂的任务。同时,这些案例还可以启发读者思考如何解决其他的问题。 这本书还提供了实践练习和思考题,帮助读者巩固所学知识,并激发读者的创造性思维。 总之,Bash shell脚本编程经典实例是一本非常有价值的书籍。它为读者提供了强大的工具,帮助读者更高效地完成日常工作,并教会了读者基本的编程技巧和方法。如果您需要使用bash shell编写脚本,这本书是一个非常好的选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值