PHP unpack()関数
❮PHPその他のリファレンス
例
バイナリ文字列からデータを解凍します。
<?php
$data = "PHP";
print_r(unpack("C*",$data));
?>
定義と使用法
unpack()関数は、バイナリ文字列からデータを解凍します。
構文
パラメータ値
Parameter |
Description |
format |
Required. Specifies the format to use when unpacking data.
Possible values:
- a - NUL-padded string
- A - SPACE-padded string
- h - Hex string, low nibble first
- H - Hex string, high nibble first
- c - signed char
- C - unsigned char
- s - signed short (always 16 bit, machine byte order)
- S - unsigned short (always 16 bit, machine byte order)
- n - unsigned short (always 16 bit, big endian byte order)
- v - unsigned short (always 16 bit, little endian byte order)
- i - signed integer (machine dependent size and byte order)
- I - unsigned integer (machine dependent size and byte order)
- l - signed long (always 32 bit, machine byte order)
- L - unsigned long (always 32 bit, machine byte order)
- N - unsigned long (always 32 bit, big endian byte order)
- V - unsigned long (always 32 bit, little endian byte order)
- q - signed long long (always 64 bit, machine byte order)
- Q - unsigned long long (always 64 bit, machine byte order)
- J - unsigned long long (always 64 bit, big endian byte order)
- P - unsigned long long (always 64 bit, little endian byte order)
- f - float (machine dependent size and representation)
- g - float (machine dependent size, little endian byte order)
- G - float (machine dependent size, big endian byte order)
- d - double (machine dependent size and representation)
- e - double (machine dependent size, little endian byte order)
- E - double (machine dependent size, big endian byte order)
- x - NUL byte
- X - Back up one byte
- Z - NUL-padded string
- @ - NUL-fill to absolute
|
data |
Required. Specifies the binary data to be unpacked |
offset |
Optional. Specifies where to start unpacking from. Default is 0. |
技術的な詳細
戻り値: |
成功した場合は配列を返し、失敗した場合はFALSEを返します。 |
PHPバージョン: |
4歳以上 |
変更ログ: |
PHP 7.2-floatとdoubleは、ビッグエンディアンとスモールエンディアンの両方をサポートするようになりました。 PHP7.1-オプションのオフセットパラメータを追加しました。 PHP 5.5.0-Perlとの互換性のために、次の変更が行われました。「a」コードは末尾のNULLバイトを保持するようになりました。 「A」コードは、末尾のASCII空白をすべて削除するようになりました。 NULLが埋め込まれた文字列に「Z」コードが追加され、末尾のNULLバイトが削除されました。 |
その他の例
例
データを解凍します:
<?php
$data = "PHP";
print_r(unpack("C*myint",$data));
?>
例
データを解凍します:
<?php
$bin = pack("c2n2",0x1234,0x5678,65,66);
print_r(unpack("c2chars/n2int",$bin));
?>
❮PHPその他のリファレンス