我偶尔会像这样运行bash命令行:
n=0; while [[ $n -lt 10 ]]; do some_command; n=$((n+1)); done
在一行中运行some_command多次——在本例中为10次。
通常some_command实际上是一个命令链或管道。
有没有更简洁的方法呢?
我偶尔会像这样运行bash命令行:
n=0; while [[ $n -lt 10 ]]; do some_command; n=$((n+1)); done
在一行中运行some_command多次——在本例中为10次。
通常some_command实际上是一个命令链或管道。
有没有更简洁的方法呢?
当前回答
使用GNU Parallel你可以做到:
parallel some_command ::: {1..1000}
如果您不希望将数字作为参数,并且一次只运行一个作业:
parallel -j1 -N0 some_command ::: {1..1000}
观看介绍视频快速介绍: https://www.youtube.com/playlist?list=PL284C9FF2488BC6D1
浏览本教程(http://www.gnu.org/software/parallel/parallel_tutorial.html)。命令行 用爱你换吧。
其他回答
在(bashref)循环构造中提到的for的替代形式如何?
此命令可重复执行此命令10次或更多次
for i in {1..10}; do **your command**; done
例如
for i in {1..10}; do **speedtest**; done
如果你的范围有一个变量,使用seq,像这样:
count=10
for i in $(seq $count); do
command
done
简单:
for run in {1..10}; do
command
done
或者作为一行程序,供那些想要轻松复制和粘贴的人使用:
for run in {1..10}; do command; done
还有另一个答案:在空参数上使用参数展开:
# calls curl 4 times
curl -s -w "\n" -X GET "http:{,,,}//www.google.com"
在Centos 7和MacOS上测试。
所有现有的答案似乎都需要bash,并且不能使用标准的BSD UNIX /bin/sh(例如,OpenBSD上的ksh)。
下面的代码可以在任何BSD上运行:
$ echo {1..4}
{1..4}
$ seq 4
sh: seq: not found
$ for i in $(jot 4); do echo e$i; done
e1
e2
e3
e4
$