mb_chr

(PHP 7 >= 7.2.0, PHP 8)

mb_chrUnicode のコードポイントに対応する文字を返す

説明

mb_chr(int $codepoint, ?string $encoding = null): string|false

Unicode のコードポイントで指定された文字を含む文字列を返します この値は、指定されたエンコーディングでエンコードされます。

この関数は、mb_ord() を補完するものです。

パラメータ

codepoint

Unicode のコードポイント値。 たとえば、 U+1F418 ELEPHANT に対応する 128024

encoding

encoding パラメータには文字エンコーディングを指定します。省略した場合、もしくは null の場合は、 内部文字エンコーディングを使用します。

戻り値

これは、指定されたエンコーディングで表現できる場合、 指定された文字を含む文字列を返します。 失敗した場合に false を返します

変更履歴

バージョン 説明
8.0.0 encoding は、nullable になりました。

例1 さまざまなコードポイントの例

<?php
$values
= [65, 63, 0x20AC, 128024];
foreach (
$values as $value) {
var_dump(mb_chr($value, 'UTF-8'));
var_dump(mb_chr($value, 'ISO-8859-1'));
}
?>

上の例の出力は以下となります。

string(1) "A"
string(1) "A"
string(1) "?"
string(1) "?"
string(3) "€"
bool(false)
string(4) ""
bool(false)

参考

  • mb_internal_encoding() - 内部文字エンコーディングを設定あるいは取得する
  • mb_ord() - 文字の Unicode コードポイントを取得する
  • IntlChar::ord() - 文字に対応する Unicode コードポイントを返す
  • chr() - 数値から、1バイトの文字列を生成する

add a note add a note

User Contributed Notes 1 note

up
0
boss3333 at laposte dot net
5 years ago
To convert the utf16 or utf8 decimal values (utf-8 can translate both encodings) to ascii characters using mb_ord, follow these steps:

Starting value:

1_Zvpxs4pf

Value converted to decimal value utf-16 or utf-8 (see ascii coding table):

49,95,90,118,112,120,115,52,112,102

recovery with mb_ord:

use: $ char = mb_chr ($ decimalValue, 'UTF-8');
return the correct character;

1, _, Z, v, p, x, s, 4, p, f

example:
$ start_String = 1_Zvpxs4pf;
$ start_String_to_Decimal = 49959011811212011552112102;
(decimal value of each character add in an array);
$ tab = [49, 95, 90, 118, 112, 120, 115, 52, 112, 102];
$ size = sizeof ($ tab);

$ tmpStr = '';

for ($ i = 0; $ i <$ size; $ i ++)
{
$ tmpStr. = mb_chr ($ tab [$ i], 'UTF-8');
}

echo $ tmpStr;

1_Zvpxs4pf
To Top