迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > PHP >

PHP 中如何正确格式化带有前导零的数字

作者:迹忆客 最近更新:2023/03/14 浏览次数:

在 PHP 中,带有前导零的数字或整数可能具有不同的值,从而导致意外的结果。

例子:

$number = 0987654321; // 十进制数
$number = 0x987654321 // 十六进制数
$number = 0b0987654321 // 二进制数

为了确保数字不会失去其本身自然的含义,可以尝试使用几种方法,比如使用字符串代替数字,或者使用诸如 substrprintf() / sprintf()str_pad 等函数。

使用字符串代替数字

最简单的方法就是用字符串代替数字。

$number = "0987654321";

何时使用:

在 PHP 中用 substr() 来添加前导零

当超过字符串长度时,此方法将从左侧截断数字。

如果 start 索引为负的话,那么返回的字符串将从字符串倒数第 start 位的字符开始。

例:

$number = 98765;
$length = 10;
$string = substr(str_repeat(0, $length).$number, - $length);

//output: 0000098765

何时使用:

在 PHP 中 printf()/sprintf() 添加前导零

当输入的长度小于输入的长度时,将输出填充固定的长度,而当输入的长度大于输入时,返回字符串。

例:

$length = 10;
$char = 0;
$type = 'd';
$format = "%{$char}{$length}{$type}"; // or "$010d";

//print and echo
printf($format, 987654321);

//store to a variable
$newFormat = sprintf($format, 987654321);

// output: 0987654321

在上例中,固定长度设置为 10,输入长度为 9,因此如果使用 printf()/sprintf 的话,将会在左侧添加一个 0

sprintf() 参数值

参数 描述
format(必需) 字符串以及如何设置变量的格式。
可能的格式值:
%%-百分号
%b-二进制
%c-引用的字符 ASCII
%d-十进制数(负数或正数)
%e-小写科学记数法
%E-大写科学记数法
%u-无符号十进制数
%f-浮点数(支持本地设置)
%F-浮点数(不支持本地设置)
%g-%e%f 的缩小版
%G-%E%F 的缩小版
%o-八进制
%s-字符串
%x-十六进制(小写)
%X-十六进制(大写)
arg1(必需) 要在第一个%符号插入的内容
arg2(可选) 要在第二个%符号插入的内容
argg++(可选) 要在第三个,第四个,等%符号插入的内容

注意:

  • 如果输入的字符串长度大于或等于填充长度,则只会返回字符串-不会省略任何字符。
  • 仅添加填充的长度小于输入的填充长度。

在 PHP 中 str_pad() 添加前导零

此方法会将字符串填充到指定字符的新长度。

例:

$length = 7;
$string = "12345";
echo str_pad($string,$length,"0", STR_PAD_LEFT);
//output: 0012345

上面的示例将 0 添加到指定的字符串中,直到匹配指定的长度(本例中为 7)为止。

** str_pad() 参数**

参数 描述
string 要填充的字符串
length 指定字符串的新长度。**注意:**如果该值小于字符串的长度,则函数不会做任何事情。
pad_string 指定用于填充的字符串。默认值为空白。
pad_type 指定填充字符串的位置。
接受的值:
STR_PAD_BOTH - 将填充字符串的两侧。
STR_PAD_LEFT - 填充字符串的左侧
STR_PAD_RIGHT - 填充到字符串的右侧

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

使用 Mysqldump 备份 MySQL 中的数据

发布时间:2023/05/09 浏览次数:192 分类:MySQL

本篇文章将介绍如何使用 mysqldump 只备份数据。 在这里,我们将探讨 --no-create-info 、--compact 、--skip-triggers 和 --no-create-db 选项。

更新 MySQL 表中的主键

发布时间:2023/05/09 浏览次数:61 分类:MySQL

本篇文章介绍如何更新 MySQL 表中的主键。 我们将使用 ALTER 命令对主键进行任何更改。更新 MySQL 表中的主键 我们可以在多种情况下更新 MySQL 表中的主键。

在 MySQL 中获取命令历史记录

发布时间:2023/05/09 浏览次数:150 分类:MySQL

本文重点介绍了在 Windows 和 Linux 中获取我们已执行的 MySQL 命令历史记录的各种方法。MySQL命令历史

Oracle 的 decode 函数在 MySQL 中的等价物

发布时间:2023/05/09 浏览次数:115 分类:MySQL

本篇文章介绍了三种替代实现,我们可以将它们用作 MySQL 中 Oracle 的 decode() 函数的等价物。 为此,我们将使用 IF()、CASE 以及 FIELD() 和 ELT() 的组合。

在 Linux 中安装 MySQL 客户端

发布时间:2023/05/09 浏览次数:72 分类:MySQL

在 Linux 中安装 MySQL 客户端的命令。Linux 和 Unix 等环境作为命令行界面工作,仅在命令的帮助下运行。

在 MySQL 中转换为十进制

发布时间:2023/05/09 浏览次数:150 分类:MySQL

有时,我们可能需要将一种数据类型转换为另一种数据类型。 下面是我们如何使用带有 DECIMAL(M,D) 的 CAST() 和 CONVERT() 函数在 MySQL 中转换为十进制。

在 MySQL 中获取当前日期和时间

发布时间:2023/05/09 浏览次数:145 分类:MySQL

本篇文章我们将学习 NOW()、CURRENT_TIMESTAMP()(也写为 CURRENT_TIMESTAMP)和 SYSDATE() 来获取 MySQL 中的当前日期和时间。 我们还将看到这三个功能之间的比较。在 MySQL 中获取当前日期和时间

更改 MySQL 服务器中的 max_allowed_packet Size

发布时间:2023/05/09 浏览次数:142 分类:MySQL

本篇文章介绍如何更改 MySQL 服务器中的 max_allowed_packet 大小。 为了了解这一点,我们将使用两个操作系统,Windows 10 和 Linux (Ubuntu)。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便