系统相关
首页 > 系统相关> > linux – GNU parallel – 作为参数的数组中的两个参数

linux – GNU parallel – 作为参数的数组中的两个参数

作者:互联网

我有一个使用gnu parallel的脚本.我想为每个“迭代”传递两个参数

在串行运行中我有类似的东西:

for (( i=0; i<=10; i++ ))
do
  a = tmp1[$i]
  b = tmp2[$i]
done

而且我想把它作为平行

func pf()
{
   a=$1
   b=$2
}
export -f pf
parallel --jobs 5 --linebuffer pf ::: <what to write here?>

解决方法:

省略你的其他平行标志只是为了保持专注……

parallel --link pf ::: A B ::: C D

这将首先运行您的函数,其中a = A,b = C,然后是a = B,b = D或

a=A b=C
a=B b=D

如果没有–link,你会得到如下的完整组合:

a=A b=C
a=A b=D
a=B b=C
a=B b=D

更新:作为Ole Tange metioned in a comment还有另一种方法,即:::运算符.如果参数的数量在每个参数位置不相同,则两个备选方案之间存在重要差异.一个例子将说明:

parallel –link pf ::: A B ::: C D E输出:

a=A b=C
a=B b=D
a=A b=E

parallel pf ::: A B ::: C D E输出:

a=A b=C
a=B b=D

–link将“换行”所以所有参数都被消耗,而:::将忽略额外的参数.我个人不喜欢当事情被默默地忽略,这就是为什么我的偏好是–link.因人而异.

标签:linux,gnu-parallel
来源: https://codeday.me/bug/20190813/1645286.html