linux脚本,在一个循环中赋值一个数组

linux脚本,在一个循环中赋值一个数组,第1张

数组的赋值 *** 作有问题,改成下面这样:

for ubootfile in $uboot_list

do

FILE=`find . -name $ubootfile -print -quit`

if [ -n "$FILE" ]then

a=(${a[@]} $FILE)

else

b=(${b[@]} $FILE)

fi

done

echo "found files:"

echo ${a[@]}

echo "missing files:"

echo ${b[@]}

下面是数组 *** 作的讲解,请参考:

数组作为一种特殊的数据结构在任何一种编程语言中都有它的一席之地,当然bashshell也不例外。本文就shell数组来做一个小的总结。

在这里只讨论一维数组的情况,关于多维数组(事实上,你得用一维数组的方法来模拟),不涉及。这里包括数组的复制,计算,删除,替换。

数组的声明:

1)array[key]=value # array[0]=one,array[1]=two

2)declare -a array # array被当作数组名

3)array=(value1 value2 value3 ... )

4)array=([1]=one [2]=two [3]=three ... )

5)array="one two three" # echo ${array[0|@|*]},把array变量当作数组来处理,但数组元素只有字符串本身

数组的访问:

1)${array[key]} # ${array[1]}

数组的删除

1)unsetarray[1] # 删除数组中第一个元素

2)unset array # 删除整个数组

计算数组的长度:

1)${#array}

2)${#array[0]}#同上。 ${#array[*]} 、${#array[@]}。注意同#{array:0}的区别

数组的提取

从尾部开始提取:

array=( [0]=one [1]=two [2]=three [3]=four )

${array[@]:1} # two three four,除掉第一个元素后所有元素,那么${array[@]:0}表示所有元素

${array[@]:0:2} # one two

${array[@]:1:2} # two three

子串删除

[root@localhostdev]# echo ${array[@]:0}

one two three four

[root@localhostdev]# echo ${array[@]#t*e} # 左边开始最短的匹配:"t*e",这将匹配到"thre"

one two e four

[root@localhostdev]# echo ${array[@]##t*e} # 左边开始最长的匹配,这将匹配到"three"

[root@localhostdev]# array=( [0]=one [1]=two [2]=three [3]=four )

[root@localhostdev]# echo ${array[@] %o} # 从字符串的结尾开始最短的匹配

one tw three four

[root@localhostdev]# echo ${array[@] %%o} # 从字符串的结尾开始最长的匹配

one tw three four

子串替换

[root@localhostdev]# array=( [0]=one [1]=two [2]=three [3]=four )

第一个匹配到的,会被删除

[root@localhostdev]# echo ${array[@] /o/m}

mne twm three fmur

所有匹配到的,都会被删除

[root@localhostdev]# echo ${array[@] //o/m}

mne twm three fmur

没有指定替换子串,则删除匹配到的子符

[root@localhostdev]# echo ${array[@] //o/}

ne tw three fur

替换字符串前端子串

[root@localhostdev]# echo ${array[@] /#o/k}

kne two three four

替换字符串后端子串

[root@localhostdev]# echo ${array[@] /%o/k}

one twk three four

[seesea@UC ~]$ cat a.txt

1

2

3

4

a

b

c

d

[seesea@UC ~]$ ar=( $(cat a.txt) )

[seesea@UC ~]$ for (( i = 0i <${#ar[@]}++i ))do echo "ar[$i] = ${ar[i]}"done

ar[0] = 1

ar[1] = 2

ar[2] = 3

ar[3] = 4

ar[4] = a

ar[5] = b

ar[6] = c

ar[7] = d

用数组更方便吧。

Linux Bash中,数组变量的赋值有两种方法:

(1) name = (value1 ... valuen)// 此时下标从0开始;

(2) name[index] = value

下面以一个简单的脚本来说明,脚本内容如下:

#!/bin/bash

#定义数组

A=(a b c def)

#把数组按字符串显示输出

echo ${A[@]}

#屏幕显示:a b c def

#数组的长度表示${#A[*]}

len=${#A[*]}

echo ${#A[*]}

#屏幕显示:4

#改变数组元素的值

A[3]='vivian'

echo ${A[*]}

#屏幕显示:a b c vivian

#循环输出数组元素

i=0

while [ $i -lt $len ]

do

echo ${A[$i]}

let i++

done

#屏幕输出:

# a

# b

# c

# vivian

#循环输出数组元素的另一种写法,注意,在条件中,用#a[@]取其个数。

for ((i=0i<${#A[@]}i=$i+1))

do

echo ${A[$i]}

done

#循环输出数组元素的另一种写法,注意,在条件中,引用变量一定要用双引号 ,否则报错。

for (( j=0j<"$len"j=j+1 ))//len表示数组长度值

do

   echo ${A[$j]}

done

#循环输出数组元素的另一种写法,注意,${A[*]}不能写成$A ,$A默认是第一个元素。 如果A="a b c ded",就可以写$A,

for value in ${A[*]}

do

echo $value

done

ps:

若a=(1 2 3 4)表示所有元素,则其只能用${a[*]}或者${a[@]}来表示。在a=(1 2 3 4)中,$a只是表示第一个元素1。

若a="1 2 3 4"表示所有元素,则其可以用${a[*]}或者${a[@]}或者$a来表示。

假如a="1 2 3 4",则array=($a)就相当于a=(1 2 3 4),不信你可以试试echo ${array[@]}。

上面的例子还可以改写成以下内容:

for value in $A

do

echo $value

done


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8351515.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-15
下一篇 2023-04-15

发表评论

登录后才能评论

评论列表(0条)

保存