その他の関数
PHP Manual

unpack

(PHP 4, PHP 5)

unpackバイナリ文字列からデータを切り出す

説明

array unpack ( string $format , string $data )

format に基づき、バイナリ文字列から配列に分解します。

分解した結果は連想配列に格納されます。 このようにするには、別のフォーマットコードを使用してそれらを スラッシュ / で区切る必要があります。 引数にリピータが含まれる場合の配列の要素名は、 指定した名前の後に順番に番号がついたものとなります。

パラメータ

format

書式コードの説明は pack() を参照ください。

data

パックされたデータ。

返り値

バイナリ文字列を切り出した要素を含む連想配列を返します。

例1 unpack() の例

<?php
$binarydata 
"\0x04\0x00\0xa0\0x00";
$array unpack("cchar/nint"$binarydata);
?>

結果の配列の内容は、値が 4 であるエントリ "chars" と値が 160 であるエントリ "int" となります。

例2 unpack() でのリピータの例

<?php
 $array 
unpack("c2chars/nint"$binarydata);
 
?>

結果の配列のエントリは "chars1"、"chars2" および "int" となります。

注意

警告

PHP は内部的に整数を符号付きで保持することに注意しましょう。 大きな値の unsigned long を切り出した場合、PHP の内部で保持された値は、 同じ大きさの符号付き整数となり、符号無しを指定して切出された場合でも 結果は負の数となります。

警告

要素に名前をつけなければ、空文字列の要素となることに注意しましょう。 つまり、名前をつけない要素が複数ある場合は、 それらのキーが同じになるためデータが上書きされてしまうということです。

例3 unpack() で名前のないキーを扱う例

<?php
$binarydata 
"\x32\x42\x00\xa0";
$array unpack("c2/n"$binarydata);
var_dump($array);
?>

結果の配列の内容は、値が 160 であるエントリ "1" と値が 66 であるエントリ "2" になります。 c で指定した最初の値が n で指定した値で上書きされます。

参考


その他の関数
PHP Manual