Zauważyłem, że istnieją dwa alternatywne sposoby budowania pętli w Zsh :
for x (1 2 3); do echo $x; done
for x in 1 2 3; do echo $x; done
Oba drukują:
1
2
3
Moje pytanie brzmi: dlaczego dwie składnie? Czy w każdym z nich występuje $x
iteracja innego typu ?
Czy bash robi podobne rozróżnienie?
Uzupełnienie:
Dlaczego działa następujący:
#!/bin/zsh
a=1
b=2
c=5
d=(a b c)
for x in $d; do print $x;done
ale ten nie ?:
#!/bin/zsh
a=1
b=2
c=5
d=(a b c)
# It complains with "parse error near `$d'"
for x $d; do print $x;done
for i ({0..4..2}) for j ({a..c}) echo "($i,$j)"
= {0,2,4}x{a,b,c}
. Średniki dotyczą najbardziej zewnętrznej pętli, a przekierowania dotyczą najbardziej wewnętrznej, a jeśli chcesz to zmienić, potrzebujesz tylko nawiasów klamrowych: for i ({0..4..2}) { for j ({a..c}) echo "($i,$j)" } | cat -n
= {1,...,9}*({0,2,4}x{a,b,c})
. Oczywiście można łączyć pętle z rozszerzeniem zsh:for i ("("{0..4..2}","{a..c}")") echo $i
for x ($d); do print $x; done
zadziała i będzie pasować do pierwszej składni, którą wyliczyłeś na początku pytania.