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

[[398680]]

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

1.声明一个数组并赋值

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

  1. name[index]=value 

name 是数组的名字。

index 可以是任何数字或表达式,值必须等于或大于零。

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

  1. [root@localhost ~]# cat arraymanip.sh 
  2. #! /bin/bash 
  3. Unix[0]='Debian' 
  4. Unix[1]='Red hat' 
  5. Unix[2]='Ubuntu' 
  6. Unix[3]='Suse' 
  7.  
  8. echo ${Unix[1]} 

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

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

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

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

  1. declare -a arrayname=(element1 element2 element3) 

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

  1. [root@localhost ~]# cat arraymain2.sh  
  2.  
  3. #! /bin/bash 
  4. declare -a Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora'
  5.  
  6. echo ${Unix[4]} 

下面是输出结果:

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

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

3.打印整个数组

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

  1. [root@localhost ~]# cat arraymain.sh  
  2. #! /bin/bash 
  3. Unix[0]='Debian' 
  4. Unix[1]='Red hat' 
  5. Unix[2]='Ubuntu' 
  6. Unix[3]='Suse' 
  7.  
  8. echo ${Unix[@]} 

下面是输出结果:

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

4.获取数组的长度

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

  1. [root@localhost ~]# cat arraymain2.sh  
  2. #! /bin/bash 
  3. declare -a Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora'
  4.  
  5. echo ${#Unix[@]} #数组中元素的数量 
  6. echo ${#Unix}  #数组中第一个元素的字符数。 

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

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

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

  1. [root@localhost ~]# cat arraymain.sh  
  2. #! /bin/bash 
  3. Unix[0]='Debian' 
  4. Unix[1]='Red hat' 
  5. Unix[2]='Ubuntu' 
  6. Unix[3]='Suse' 
  7.  
  8. echo ${#Unix[3]} #位于索引3的元素的长度。 

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

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

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

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

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

以下是输出,

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

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

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

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

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

以下是输出:

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

8.搜索并替换数组元素

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

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

以下是输出:

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

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

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

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

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

以下是输出:

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

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

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

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

  1. [root@localhost ~]# cat arraymain.sh  
  2. #! /bin/bash 
  3. Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora' 'UTS' 'OpenLinux'
  4.  
  5. unset Unix[1] 
  6.  
  7. echo ${Unix[@]} 
  8. echo ${Unix[1]} 

以下为输出:

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

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

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

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

以下为输出:

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

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

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

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

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

以下为输出:

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

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

12.复制数组

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

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

以下为输出:

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

13.两个数组的关联

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

  1. [root@localhost ~]# cat arraymain.sh  
  2. #!/bin/bash 
  3. Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora' 'UTS' 'OpenLinux'); 
  4. Shell=('bash' 'csh' 'jsh' 'rsh' 'ksh' 'rc' 'tcsh'); 
  5.  
  6. UnixShell=("${Unix[@]}" "${Shell[@]}"
  7. echo ${UnixShell[@]} 
  8. echo ${#UnixShell[@]} 

以下为输出:

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

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

14.删除整个数组

unset用于删除整个数组。

  1. [root@localhost ~]# cat arraymain.sh  
  2. #!/bin/bash 
  3. Unix=('Debian' 'Red hat' 'Ubuntu' 'Suse' 'Fedora' 'UTS' 'OpenLinux'); 
  4. Shell=('bash' 'csh' 'jsh' 'rsh' 'ksh' 'rc' 'tcsh'); 
  5.  
  6. UnixShell=("${Unix[@]}" "${Shell[@]}"
  7.  
  8. unset UnixShell 
  9. echo ${#UnixShell[@]} 

以下为输出:

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

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

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

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

  1. [root@localhost ~]# cat loadcontent.sh  
  2. #!/bin/bash 
  3. file=(`cat ./pic.txt`) 
  4.  
  5. for i in "${file[@]}" 
  6. do 
  7. echo $i 
  8. done 
  9.  
  10. echo -e "\033[31m Read file content! \033[0m" 

以下为输出:

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

 

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

本文转载自微信公众号「Linux就该这么学」,可以通过以下二维码关注。转载本文请联系Linux就该这么学公众号。

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/148577.html<

(0)
运维的头像运维
上一篇2025-03-12 05:28
下一篇 2025-03-12 05:30

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注