[英]loops in shell script
我有两组数据,例如a=file1 file2 file3
和b=location1 location2 location3
。 现在我需要遍历和复制file1
到location1
, file2
至location2
和file3
至location3
。
如果我使用for循环,则在内循环的第一次迭代之后,它应该返回外循环,获取第二个值,转到内循环并获取第二个值,依此类推。 基本上,内部循环不应针对外部循环中的每个值进行迭代。
有没有办法做到这一点?
提前致谢。 苏迪尔
听起来您变得太复杂了:
a=(file1 file2 file3)
b=(location1 location2 location3)
for (( idx=0; idx<${#a[@]}; idx++ )); do
cp -v "${a[idx]}" "${b[idx]}"
done
您可以创建bash数组并使其适合您:
declare -a f=( "file1" "file2" "file3" )
declare -a d=( "location1" "location2" "location3" )
c=0
for i in ${f[@]}; do
echo $i ${d[$c]}
((c++))
done
如果没有数组,则类似以下脚本的内容也应该适合您:
ci=0
for i in file1 file2 file3; do
((ci++))
cj=1
for j in location1 location2 location3; do
[[ $ci = $cj ]] && echo $i $j && break
((cj++))
done
done
file1 location1
file2 location2
file3 location3
可以肯定, $SHELL
在这里是最简单的,尽管一旦您开始使用bash
进行数组操作,优势就会消失;-)因此,为了进行比较,这是一种简单的,非单一的perl
方法:
#!/usr/bin/env perl
my @arraya = qw/ file1 file2 file3/ ;
my @arrayb = qw/ location1 location2 location3/ ;
foreach my $i ( 0 .. $#arraya ) {`cp $arraya[$i] $arrayb[$i]` }
@arraya
和@arrayb
可通过/m//
匹配和过滤, grep
ing, find
等方式以编程方式构造成非常大的列表。
参见基于perl
的rename
工具。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.