【10-4】做数据分析,要不要掌握Linux系列:shell编程之数组和函数!
一、数组
1、shell中的数组
1)数组中可以存放多个值。
2)bash shell中只支持一维数组,不支持多维数组。
3)初始化数组的时候,不需要定义数组的大小。
4)数组元素的下标从0开始,下标可以不连续。
2、定义数组
注意:在Shell中,用括号来表示数组,数组元素用"空格"符号分割开。
// 第一种定义方式:静态定义数组
// 在定义数组的是同时,直接给定数组的值;
array=(value0 value1 value2... valuen)
// 第二种定义方式:动态定义数组
array[0]=value0
array[1]=value1
......
array[n]=valuen
3、读取数组中每个元素
// 格式如下
${数组名[index]}
// array[0]为一个整体,获取数组中每个变量值要用{}括起来。
// ${}表示获取某个变量的值。
[hadoop@image ~]$ array=(1 3 5 7 9)
[hadoop@image ~]$ echo ${array[0]}
1
[hadoop@image ~]$ echo ${array[1]}
3
[hadoop@image ~]$ echo ${array[4]}
9
4、获取数组中所有的元素:@ 和 *
// 格式如下
${数组名[@]}
${数组名[*]}
// 操作如下
[hadoop@image ~]$ array=(1 3 5 7 9)
[hadoop@image ~]$ echo ${array[@]}
1 3 5 7 9
[hadoop@image ~]$ echo ${array[*]}
1 3 5 7 9
5、获取数组的长度:#
// 格式如下:这里只是多了一个#号,注意和上面的区别
${#数组名[@]}
${#数组名[*]}
// 操作如下
[hadoop@image ~]$ array=(1 3 5 7 9)
[hadoop@image ~]$ echo ${#array[@]}
5
[hadoop@image ~]$ echo ${#array[*]}
5
二、函数
1、函数的定义
// 函数最后可以使用return返回值,也可以不使用return返回值。
函数名(){
函数体
[return ...]
}
不带返回值return:
[hadoop@image shell]$ cat func1.sh
#!/bin/bash
func1(){
a=1
b=9
let c=a+b
echo $c
}
func1
结果如下:
[hadoop@image shell]$ . func1.sh
10
下面让大家写一个带返回值return的函数,你会吗?