在 for 迴圈中將每對字串重複兩次

在 for 迴圈中將每對字串重複兩次

我需要傳遞給 pdftk,一個由重複兩次的字串組成的參數列表,如下所示:

A1-2 B1-2 A3-4 B3-4 A5-6 B5-6...等等...

我成功地透過這個解決方法實現了這一點

for ((x=1, y=2;x>=18, y<=18;x++, y++)); do echo "A$x-$y B$x-$y "; done| awk 'NR %2==1 {print $1, $2} ' | tr '\n' ' '

這給出了:

A1-2 B1-2 A3-4 B3-4 A5-6 B5-6 A7-8 B7-8 A9-10 B9-10 A11-12 B11-12 A13-14 B13-14 A15-16 B15-16 A17- 18 B17-18

但我不滿意,我正在尋找一種合適的、更優雅的、更好的方法來執行這項任務

答案1

for ((x=1; x<=18; x+=2)); do echo -n "A$x-$((x+1)) B$x-$((x+1)) "; done

答案2

甚至是純 awk:

awk 'BEGIN {for (i=1; i<19; i+=2) printf "A"i"-"i+1 " B"i"-"i+1" "}'

答案3

只需 bash:

pdftk input.pdf cat $(for ((x=1; x<18; x+=2)); do echo {A,B}$x-$((x+1)); done) output output.pdf

使用 GNU 實用程式(Linux 或 Cygwin):

pdftk input.pdf cat $(seq 1 2 17 | awk '{$1 = $1 "-" ($1+1); print "A" $1; print "B" $1}') output output.pdf

使用 Perl:

pdftk input.pdf cat $(perl -e 'print map {"A$_ B$_ "} map {(2*$_-1) . "-" . (2*$_)} (1..9)') output output.pdf

相關內容