博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
linux shell 数组建立及使用技巧
阅读量:2380 次
发布时间:2019-05-10

本文共 1567 字,大约阅读时间需要 5 分钟。

原文地址为:

linux shell在编程方面比windows 批处理强大太多,无论是在循环、运算。已经数据类型方面都是不能比较的。 下面是个人在使用时候,对它在数组方面一些操作进行的总结。

 

1.数组定义

 

[chengmo@centos5 ~]$ a=(1 2 3 4 5)

[chengmo@centos5 ~]$ echo $a
1

 

一对括号表示是数组,数组元素用“空格”符号分割开。

 

2.数组读取与赋值

  • 得到长度

[chengmo@centos5 ~]$ echo ${#a[@]}

5

用${#数组名[@或*]} 可以得到数组长度

  • 读取

[chengmo@centos5 ~]$ echo ${a[2]}

3

[chengmo@centos5 ~]$ echo ${a[*]}

1 2 3 4 5   

用${数组名[下标]} 下标是从0开始  下标是:*或者@ 得到整个数组内容

  • 赋值:

[chengmo@centos5 ~]$ a[1]=100

[chengmo@centos5 ~]$ echo ${a[*]}

1 100 3 4 5

 

[chengmo@centos5 ~]$ a[5]=100    

[chengmo@centos5 ~]$ echo ${a[*]}

1 100 3 4 5 100

直接通过 数组名[下标] 就可以对其进行引用赋值,如果下标不存在,自动添加新一个数组元素

  • 删除:

[chengmo@centos5 ~]$ a=(1 2 3 4 5)

[chengmo@centos5 ~]$ unset a
[chengmo@centos5 ~]$ echo ${a[*]}

[chengmo@centos5 ~]$ a=(1 2 3 4 5)

[chengmo@centos5 ~]$ unset a[1]  
[chengmo@centos5 ~]$ echo ${a[*]}
1 3 4 5
[chengmo@centos5 ~]$ echo ${#a[*]}
4

直接通过:unset 数组[下标] 可以清除相应的元素,不带下标,清除整个数据。

 

 

3.特殊使用

  • 分片:

[chengmo@centos5 ~]$ a=(1 2 3 4 5)

[chengmo@centos5 ~]$ echo ${a[@]:0:3}
1 2 3
[chengmo@centos5 ~]$ echo ${a[@]:1:4}
2 3 4 5

[chengmo@centos5 ~]$ c=(${a[@]:1:4})

[chengmo@centos5 ~]$ echo ${#c[@]}
4
[chengmo@centos5 ~]$ echo ${c[*]}
2 3 4 5

直接通过 ${数组名[@或*]:起始位置:长度} 切片原先数组,返回是字符串,中间用“空格”分开,因此如果加上”()”,将得到切片数组,上面例子:c 就是一个新数据。

  • 替换:

[chengmo@centos5 ~]$ a=(1 2 3 4 5)   

[chengmo@centos5 ~]$ echo ${a[@]/3/100}
1 2 100 4 5
[chengmo@centos5 ~]$ echo ${a[@]}
1 2 3 4 5
[chengmo@centos5 ~]$ a=(${a[@]/3/100})
[chengmo@centos5 ~]$ echo ${a[@]}    
1 2 100 4 5

调用方法是:${数组名[@或*]/查找字符/替换字符} 该操作不会改变原先数组内容,如果需要修改,可以看上面例子,重新定义数据。

 

从上面讲到的,大家可以发现linux shell 的数组已经很强大了,常见的操作已经绰绰有余了。

转载请注明本文地址:
你可能感兴趣的文章
hive 数据类型
查看>>
Hbase master HA使用
查看>>
Hbase region 管理
查看>>
Hbase 计数器
查看>>
排序算法 -- 直接插入排序
查看>>
树的基本概念
查看>>
Java命令行工具 -- jps
查看>>
storm 单机环境搭建
查看>>
MongoDB 副本集环境搭建
查看>>
sqoop导出avro格式文件报错
查看>>
spark sql 访问Hive数据表
查看>>
Ambari 启动 oozie UI
查看>>
mongodb报错:com.mongodb.MongoCursorNotFoundException
查看>>
mongodb报错:com.mongodb.MongoSocketReadException: Exception receiving message
查看>>
spark本地程序报错
查看>>
spark从postgresql导入数据至mongodb报错: Decimal precision 39 exceeds max precision 38
查看>>
BufferedReader读取中文文本乱码
查看>>
内网环境centos7 yum离线安装软件包
查看>>
linux 文件的三个时间
查看>>
secureCRT在Windows和Linux间传输大于4G文件解决方案
查看>>