IPアドレスをバイナリ形式に変換するコマンドはありますか?
例: 10.110.11.116
出力: 00001010.01101110.00001011.01110100
さて、これを行うための1つの(非常に複雑な)方法があります:
pax> export ip=10.110.11.116
pax> for i in $(echo ${ip} | tr '.' ' '); do echo "obase=2 ; $i" | bc; done
| awk '{printf ".%08d", $1}' | cut -c2-
00001010.01101110.00001011.01110100
このecho/tr
ステートメントは、スペースで区切られたオクテットのリストと、for
これらを一度に1つずつ処理するプロセスを提供します。
bc
それぞれについて、出力ベースを2(バイナリ)に設定してパススルーします。次に、可変長の2進数のこれらの4行を通過awk
して、サイズを8に強制し、1行に戻し、それぞれの前にa.
を付け、最後cut
に最初のを削除し.
ます。
もちろん、これを行うためのより良い方法があることはほぼ確実ですが、これは、少しの工夫とUNIXでのプレイに何十年も費やしたことで何ができるかを示しています:-)
これを行う1つの方法があります-ただし、2進数の先行ゼロはありません。
IP=192.168.4.254
echo $IP | tr '.' '\n' | while read octet
do
echo "2 o $octet p" | dc
done | tr '\n' '.'
または、dc への単一の呼び出しとして:
IP=192.168.4.254
echo $IP | tr '.' ' ' | while read octet1 octet2 octet3 octet4
do
echo "2 o $octet1 p $octet2 p $octet3 p $octet4 p" | dc | tr '\n' '.'
done
外部ユーティリティなしで Bash で動作する方法を次に示します。
tobin ()
{
local val bits b c d;
val=$1;
bits="";
(( val < 2 )) && bits=$val;
b="";
while (( val > 1 )); do
bits=$b$bits;
(( b = val % 2 ));
(( c = ( val / 2 ) * ( val % 2 ) ));
(( val = val / 2 ));
(( d = val ));
done;
echo "$d$c$bits"
}
byte () { printf "%08d" $1; }
unset dot binary
saveIFS=$IFS
IFS=.
ip=($1)
IFS=saveIFS
for octet in ${ip[@]}
do
binary=$binary$dot$(byte $(tobin $octet))
dot=.
done
echo $binary
POSIX 準拠の Bourne シェルの場合:
tobin () {
local val bits b c d
val=$1
bits=""
if [ $val -lt 2 ]
then
bits=$val
fi
b=""
while [ $val -gt 1 ]
do
bits=$b$bits
b=$(($val%2))
c=$((($val/2)*($val%2)))
val=$(($val/2))
d=$val
done
echo "$d$c$bits"
}
byte () { printf "%08d" $1; } # printf may be an external utility in some shells
unset dot binary
saveIFS=$IFS
IFS=.
set -- $a
IFS=$saveIFS
for octet
do
binary=$binary$dot$(byte $(tobin $octet))
dot=.
done
echo $binary