当前位置: 首页 > 工具软件 > GNU parallel > 使用案例 >

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

丁振海
2023-12-01

我有一个使用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

 类似资料: