Ich weiß, wie durch Alphabete iterieren:Wie durchläuft man alle ASCII-Zeichen in Bash?
for c in {a..z}; do ...; done
Aber ich kann nicht herausfinden, wie durch alle ASCII-Zeichen zu durchlaufen. Weiß jemand wie?
Ich weiß, wie durch Alphabete iterieren:Wie durchläuft man alle ASCII-Zeichen in Bash?
for c in {a..z}; do ...; done
Aber ich kann nicht herausfinden, wie durch alle ASCII-Zeichen zu durchlaufen. Weiß jemand wie?
Was Sie tun können, ist iterate fr om 0 bis 127 und dann den Dezimalwert in seinen ASCII-Wert (oder zurück) konvertieren.
Sie these Funktionen nutzen zu können, es zu tun:
# POSIX
# chr() - converts decimal value to its ASCII character representation
# ord() - converts ASCII character to its decimal value
chr() {
[ ${1} -lt 256 ] || return 1
printf \\$(printf '%03o' $1)
}
# Another version doing the octal conversion with arithmetic
# faster as it avoids a subshell
chr() {
[ ${1} -lt 256 ] || return 1
printf \\$(($1/64*100+$1%64/8*10+$1%8))
}
# Another version using a temporary variable to avoid subshell.
# This one requires bash 3.1.
chr() {
local tmp
[ ${1} -lt 256 ] || return 1
printf -v tmp '%03o' "$1"
printf \\"$tmp"
}
ord() {
LC_CTYPE=C printf '%d' "'$1"
}
# hex() - converts ASCII character to a hexadecimal value
# unhex() - converts a hexadecimal value to an ASCII character
hex() {
LC_CTYPE=C printf '%x' "'$1"
}
unhex() {
printf \\x"$1"
}
# examples:
chr $(ord A) # -> A
ord $(chr 65) # -> 65
Hier ist, wie Sie eine ganze Zahl als ihre entsprechenden ASCII-Zeichen mit awk
drucken:
echo "65" | awk '{ printf("%c", $0); }'
, die gedruckt werden:
A
Und hier ist, wie Sie durch den Großbuchstaben Alphabet auf diese Weise durchlaufen könnte:
# ascii for A starts at 65:
ascii=65
index=1
total=26
while [[ $total -ge $index ]]
do
letter=$(echo "$ascii" | awk '{ printf("%c", $0); }')
echo "The $index'th letter is $letter"
# Increment the index counter as well as the ascii counter
index=$((index+1))
ascii=$((ascii+1))
done
Nun ... Wenn Sie wirklich alle wollen, dass sie, und Sie wollen es etwas Skript artig sein, können Sie dies tun, ich denke:
awk 'function utf32(i) {printf("%c%c%c%c",i%0x100,i/0x100%0x100,i/0x10000%0x100,i/0x1000000) } BEGIN{for(i=0;i<0x110000;i++){utf32(i);utf32(0xa)}}' | iconv --from-code=utf32 --to-code=utf8 | grep -a '[[:print:]]'
Aber die Liste ist ziemlich groß, und nicht sehr nützlich. Awk ist vielleicht nicht die eleganteste Art, binäre Ganzzahlen von 0 bis 0x110000 zu erzeugen - ersetze etwas Eleganteres, wenn du es findest.
Edit: Oh, ich sehe, Sie wollten nur ascii. Nun, ich werde diese Antwort hier lassen, für den Fall, dass jemand anderes alle druckbaren UTF-Zeichen möchte.
Eine Möglichkeit nur echo
s Oktal-Escape-Sequenzen mit:
for n in {0..7}{0..7}{0..7}; do echo -ne "\\0$n"; done
Hier ist, was ich mit kam für ein Einzeiler einige Stücke von Sampson-chen und mata die Antworten unter:
for n in {0..127}; do awk '{ printf("%c", $0); }' <<< $n; done
Oder alternativ:
for n in {0..127}; do echo $n; done | awk '{ printf("%c", $0); }'
Beachten Sie, dass 0-31 normalerweise nicht als "druckbar" betrachtet werden, mit Ausnahme von th e Leerzeichen (Wagenrücklauf, Zeilenumbruch und horizontaler und vertikaler Tabulator). – twalberg