Dado um arquivo, quero fazer uma lista de todos os bytes que ele contém em formato octal, cada byte em sua própria linha.
Por que isso funciona:
#!/bin/sh --
newline='
'
od -v -A n -t o1 -- /tmp/file | \
sed -e "s/ /\\${newline}/g" | \
sed -e '/^$/d'
e não isso:
#!/bin/sh --
newline='
'
od -v -A n -t o1 -- /tmp/file | \
sed -e "s/ /\\${newline}/g" -e '/^$/d'
Por que eu tenho que ligar para o sed duas vezes separadas para fazer o trabalho?
Para referência, a saída de od
, sem processamento adicional, pode ser algo como o seguinte:
047 124 167 141 163 040 142 162 151 154 154 151 147 054 040 141
156 144 040 164 150 145 040 163 154 151 164 150 171 040 164 157
166 145 163 012 011 104 151 144 040 147 171 162 145 040 141 156
144 040 147 151 155 142 154 145 040 151 156 040 164 150 145 040
167 141 142 145 072 012 101 154 154 040 155 151 155 163 171 040
167 145 162 145 040 164 150 145 040 142 157 162 157 147 157 166
145 163 054 012 011 101 156 144 040 164 150 145 040 155 157 155
145 040 162 141 164 150 163 040 157 165 164 147 162 141 142 145
056 012