我有一个使用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 :::
解决方法:
省略你的其他平行标志只是为了保持专注……
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