请注意,如果数字高于 256,它将返回数字模 256。
例如
chr(321)=A 因为 A=65(256)
(PHP 4, PHP 5, PHP 7, PHP 8)
chr — 根据数字生成单字节字符串
返回一个单字符字符串,该字符串包含通过将 codepoint
解释为无符号整数指定的字符。
这可用于在单字节编码(例如 ASCII、ISO-8859 或 Windows 1252)中创建一个单字符字符串,方法是传递编码映射表中所需字符的位置。但是,请注意,此函数不了解任何字符串编码,特别是不能传递 Unicode 代码点值来在多字节编码(如 UTF-8 或 UTF-16)中生成字符串。
此函数与 ord() 互补。
codepoint
0 到 255 之间的整数。
超出有效范围 (0..255) 的值将与 255 进行按位与运算,这等效于以下算法
while ($bytevalue < 0) {
$bytevalue += 256;
}
$bytevalue %= 256;
包含指定字节的单字符字符串。
版本 | 描述 |
---|---|
7.4.0 | 该函数不再静默接受不受支持的 codepoint ,并将这些值强制转换为 0 。 |
示例 #1 chr() 示例
<?php
// 假设字符串将用作 ASCII 或与 ASCII 兼容的编码
$str = "The string ends in escape: ";
$str .= chr(27); /* 在 $str 的末尾添加转义字符 */
/* 通常这更有用 */
$str = sprintf("The string ends in escape: %c", 27);
?>
示例 #2 溢出行为
<?php
echo chr(-159), chr(833), PHP_EOL;
?>
上面的例子将输出
aA
示例 #3 从单个字节构建 UTF-8 字符串
<?php
$str = chr(240) . chr(159) . chr(144) . chr(152);
echo $str;
?>
上面的例子将输出
%c
另一个快速简短的函数,用于通过其代码获取 Unicode 字符。
<?php
/**
* 通过其代码返回 Unicode 字符
*
* @param int $u
* @return char
*/
function unichr($u) {
return mb_convert_encoding('&#' . intval($u) . ';', 'UTF-8', 'HTML-ENTITIES');
}
?>
我花了几个小时寻找一个函数,该函数可以接收数值 HTML 实体值并输出相应的 UTF-8 字节。我在另一个站点找到了这个函数,并且只需要稍作修改;所以我对此不承担任何责任。
<?php function unichr($dec) {
if ($dec < 128) {
$utf = chr($dec);
} else if ($dec < 2048) {
$utf = chr(192 + (($dec - ($dec % 64)) / 64));
$utf .= chr(128 + ($dec % 64));
} else {
$utf = chr(224 + (($dec - ($dec % 4096)) / 4096));
$utf .= chr(128 + ((($dec % 4096) - ($dec % 64)) / 64));
$utf .= chr(128 + ($dec % 64));
}
return $utf;
} ?>
例如
<?php
$str = "Chinese: 中文";
$str = preg_replace("/&#(\d{2,5});/e", "unichr($1);", $str);
?>
这是一个使用“chr”和“ord”进行编码和解码的示例。
<?php
function Encode($txtData,$Level){
for ($j = 0;$j<$Level;$j++){
$tmpStr = '';
for ($i = 0;$i<strlen($txtData);$i++)
$tmpStr .= ord(substr(strtoupper($txtData), $i, 1));
$txtData = $tmpStr;
}
return (strlen($Level)).$Level.$txtData;
}
function Decode($txtData){
$intLevel = substr($txtData, 1, substr($txtData, 0, 1));
$startStr = substr($txtData, substr($txtData, 0, 1)+1, strlen($txtData));
for ($j = 0;$j<$intLevel;$j++){
for ($i = 0;$i<strlen($startStr);$i+=2)
$tmpStr .= chr(intval(substr($startStr, $i, 2)));
$startStr = $tmpStr;
$tmpStr = "";
}
return $startStr;
}
echo Encode('123',4).'<br>';
echo Decode(Encode('123',5));
?>
<?php
for ($i = 128; $i <= 191; $i++) {
$str = chr(240) . chr(159) . chr(144) . chr($i);
echo $str;
}
?>
// rivencodec 1.0
// 编码反向ASCII码,一个简单的函数可以进行编码/解码
// 可用于安全地以高速编码文本的源代码
<?php
function rivencodec($ch,$a=0) {
while((@$b = $ch[$a++])) { $ch[$a-1] = chr(255-ord($b)); }
return $ch;
}
$zz = rivencodec("abcdefghijklmn");
echo 'encode: ',$zz,'<br/>',PHP_EOL;
$yy = rivencodec($zz);
echo 'decode: ',$yy,'<br/>',PHP_EOL;
?>
想要在命令行PHP脚本中使用终端颜色吗?
这应该可以解决这个问题。
<?
$_colors = array(
'LIGHT_RED' => "[1;31m",
'LIGHT_GREEN' => "[1;32m",
'YELLOW' => "[1;33m",
'LIGHT_BLUE' => "[1;34m",
'MAGENTA' => "[1;35m",
'LIGHT_CYAN' => "[1;36m",
'WHITE' => "[1;37m",
'NORMAL' => "[0m",
'BLACK' => "[0;30m",
'RED' => "[0;31m",
'GREEN' => "[0;32m",
'BROWN' => "[0;33m",
'BLUE' => "[0;34m",
'CYAN' => "[0;36m",
'BOLD' => "[1m",
'UNDERSCORE' => "[4m",
'REVERSE' => "[7m",
);
function termcolored($text, $color="NORMAL", $back=1){
global $_colors;
$out = $_colors["$color"];
if($out == ""){ $out = "[0m"; }
if($back){
return chr(27)."$out$text".chr(27).chr(27)."[0m".chr(27);
}else{
echo chr(27)."$out$text".chr(27).chr(27)."[0m".chr(27);
}//fi
}// end function
echo termcolored("test\n", "BLUE");
?>
删除ASCII控制字符(除了“换行符”和“制表符”)
$tab_chr = array() ;
for($control = 0; $control < 32; $control++) {
if ($control != 9 && $control != 10) {
$tab_chr[]= chr($control) ;
}
}
$tab_chr[]= chr(127) ;
$string = str_replace($tab_chr, '', $string);
在处理解析IIS4或IIS5元数据库转储时,我编写了一个简单的函数来将那些MS十六进制值转换为其ASCII对应部分。希望有人能用得上。
<?php
function hex_decode($string) {
for ($i=0; $i < strlen($string); $i++) {
$decoded .= chr(hexdec(substr($string,$i,2)));
$i = (float)($i)+2;
}
return $decoded;
}
?>
除了替换Microsoft Windows智能引号(如sgaston在2006-02-13演示的那样),我还使用字符代码专家[2] Jukka Korpela发布的建议[1]替换所有其他Microsoft Windows字符。
<?php
$str = str_replace(chr(130), ',', $str); // 基线单引号
$str = str_replace(chr(131), 'NLG', $str); // 荷兰盾
$str = str_replace(chr(132), '"', $str); // 基线双引号
$str = str_replace(chr(133), '...', $str); // 省略号
$str = str_replace(chr(134), '**', $str); // 双剑号(第二个脚注)
$str = str_replace(chr(135), '***', $str); // 三剑号(第三个脚注)
$str = str_replace(chr(136), '^', $str); // 抑扬符
$str = str_replace(chr(137), 'o/oo', $str); // 千分号
$str = str_replace(chr(138), 'Sh', $str); // S弯音符
$str = str_replace(chr(139), '<', $str); // 左单引号
$str = str_replace(chr(140), 'OE', $str); // OE连字
$str = str_replace(chr(145), "'", $str); // 左单引号
$str = str_replace(chr(146), "'", $str); // 右单引号
$str = str_replace(chr(147), '"', $str); // 左双引号
$str = str_replace(chr(148), '"', $str); // 右双引号
$str = str_replace(chr(149), '-', $str); // 实心圆点
$str = str_replace(chr(150), '-', $str); // 短破折号
$str = str_replace(chr(151), '--', $str); // 长破折号
$str = str_replace(chr(152), '~', $str); // 代字号
$str = str_replace(chr(153), '(TM)', $str); // 商标符号
$str = str_replace(chr(154), 'sh', $str); // s弯音符
$str = str_replace(chr(155), '>', $str); // 右单引号
$str = str_replace(chr(156), 'oe', $str); // oe连字
$str = str_replace(chr(159), 'Y', $str); // Y分音符
?>
[1] 关于在HTML中使用一些MS Windows字符
http://www.cs.tut.fi/~jkorpela/www/windows-chars.html
[2] Jukka Korpela 解释 Unicode
http://www.amazon.com/dp/059610121X/
具有可变最大符号数量的安全密码生成器。
<?php
function passwdGen($minLength = 8, $maxLength = 12, $maxSymbols = 2)
{
$symbolCount = 0;
srand((double)microtime() * 1000003);
for ($i = 0; $i < rand($minLength, $maxLength); $i++)
{
do
{
$char = rand(33, 126);
$symbolCount += $isSymbol = (!in_array($char, range(48, 57)) && !in_array($char, range(65, 90)) && !in_array($char, range(97, 122)));
if ($symbolCount <= $maxSymbols || !$isSymbol)
{
break;
}
}
while (true);
$passwd = sprintf('%s%c', isset($passwd) ? $passwd : NULL, $char);
}
return $passwd;
}
?>
这是一个函数,它可以帮助我比输入256个echo标签更快地找到chr(number)输出什么字符。
<?php
function listChr(){
for ($i = 0; $i < 256; ++$i) {
static $genNum;
$genNum++;
echo "chr($genNum) will output '";
echo (chr($genNum));
echo "'< br>\n";
}
}
listChr();
?>
另一个有用的chr是#9,它是一个制表符。在创建错误日志时非常有用。
$tab = (chr(9));
echo "<pre>error{$tab}date{$tab}time</pre>";
-- HappyEvil
我需要生成一个无效的UTF-8字符来测试JSON。这招奏效了
<?php
echo 'Bogus UTF-8 character at end' . chr(0xC6) ;
另一个快速函数,通过其代码获取Unicode字符。
<?php
function unichr($dec)
{
if ($dec < 0x80)
{
$utf = chr($dec);
}
else if ($dec < 0x0800)
{
$utf = chr(0xC0 + ($dec >> 6));
$utf .= chr(0x80 + ($dec & 0x3f));
}
else if ($dec < 0x010000)
{
$utf = chr(0xE0 + ($dec >> 12));
$utf .= chr(0x80 + (($dec >> 6) & 0x3f));
$utf .= chr(0x80 + ($dec & 0x3f));
}
else if ($dec < 0x200000)
{
$utf = chr(0xF0 + ($dec >> 18));
$utf .= chr(0x80 + (($dec >> 12) & 0x3f));
$utf .= chr(0x80 + (($dec >> 6) & 0x3f));
$utf .= chr(0x80 + ($dec & 0x3f));
}
else
{
die("UTF-8 字符大小超过 4 个字节");
}
return $utf;
}
echo unichr(0x263A);
?>
使用 sprintf 和 %c 类型说明符的简单密码生成函数;它与 chr() 相同。
function genPass($len = 8) {
for ($i=0;$i<=$len;$i++) {
$passwd = sprintf('%s%c', isset($passwd) ? $passwd : NULL, rand(48, 122));
}
return $passwd;
}
[编辑注
%c 定义为:“打印属于给定 ASCII 码的字符”
chr() 只返回一个字符串,因此您需要使用 %s,即使该字符串只包含一个字符。这与其他语言一致。
[email protected]]
从我的错误中学习
不要指望这个能工作!
<?php
$c_question = chr(63);
$v_out = sprintf("<%cphp\n", $c_question);
//...更多使用 sprintf 写入 v_out 的内容在这里 ...
$v_out = sprintf("%s%c>\n", $v_out, $c_question);
$v_fp = fopen("foofile", "w");
if ($v_fp)
{
fwrite($v_fp, $v_out, strlen($v_out));
fclose($v_fp);
}
?>
当我这样做时,foofile 包含 <NUL NUL NUL NUL NUL>。
我花了好一会儿时间查看 fputs、fwrite 以验证我是否正确调用了这些函数。
我的错误是使用了 $c_question = chr(63) 而不是
$c_question = 63(正确)。然后一切正常。
请注意,chr(10) 是“换行符”,chr(13) 是“回车符”,它们并不相同!我在尝试解析来自表单和文本文件的文本以将其作为 HTML 包含(通过将所有回车符替换为 <BR>)时发现了这一点,结果发现我应该查找换行符。如果有人能解释一下它们的区别,请务必告知。
如果您计划将文本从表单保存到数据库以便稍后显示,则需要应用以下函数,以便它以正确的 HTML 标记保存。
<?php
$text = str_replace ( chr(10), "<BR>", $text );
?>
当您想将其重新插入表单进行编辑时,您需要将其转换回来。
<?php
$text = str_replace ( "<BR>", chr(10), $text)
?>
希望这能为某些人节省一些麻烦。 :)
string mb_chr ( int $cp [, string $encoding ] )
参数列表
cp - 字符代码(十进制表示)
encoding - 编码(UTF-8、ASCII 等)
我们从 UTF-8 编码中得到字母“Ж”
$sim = mb_chr(0x0416, 'UTF-8');
echo $sim; // Ж
从 ASCII 编码中获取字符“}”
$sim = mb_chr(125, 'ASCII');
echo $sim ; // }
PHP 似乎使用的是此处的表格:http://ascii-code.com/
(而不是文档中建议的此处:http://www.asciitable.com/)用于代码 128 到 255。
<?php
for ($i = 32; $i <= 255; $i++) {
echo chr($i);
}
?>
支持 Unicode 的 chr()
<?php
function uchr ($codes) {
if (is_scalar($codes)) $codes= func_get_args();
$str= '';
foreach ($codes as $code) $str.= html_entity_decode('&#'.$code.';',ENT_NOQUOTES,'UTF-8');
return $str;
}
echo uchr(23383); echo '<br/>';
echo uchr(23383,215,23383); echo '<br/>';
echo uchr(array(23383,215,23383,215,23383)); echo '<br/>';
?>
我正在寻找一种使用 chr() 和模运算构造类似 Excel 列标识符(例如:A B .... AA AB AC 等)的简单方法,但存在一些神奇之处……
https://php.net/manual/en/language.operators.increment.php
所以,这也行得通
<?php
$p = chr(65); // 或简写为 $p = 'A';
for ($i = 1; $i < 53; $i++){
echo $p++ . " - ";
if ($i % 10 == 0) echo '</br>';
}
?>
输出结果
A - B - C - D - E - F - G - H - I - J -
K - L - M - N - O - P - Q - R - S - T -
U - V - W - X - Y - Z - AA - AB - AC - AD -
AE - AF - AG - AH - AI - AJ - AK - AL - AM - AN -
AO - AP - AQ - AR - AS - AT - AU - AV - AW - AX -
AY - AZ -
chr() 函数也接受负数作为 ASCII 码,因此 chr(-number) 等于 chr((number%256)+256)。
对于大于 255 的 ASCII 码,结果为 chr(number%256)。
我们可以用一个小脚本测试一下
<?php
for($i=-300; $i<300; $i++){
echo "Ascii $i\t" . ord(chr($i)) . "\n";
}
?>