如何为 JSON 序列化中的不同浮点字段指定独立的小数精度

在 PHP 中,json_encode() 默认会省略浮点数末尾的零,且全局 serialize_precision 无法为各字段单独设置精度;本文介绍通过 number_format() 预处理字段值,实现按需控制每位浮点数的小数位数,并说明其字符串转换本质及使用注意事项。 在 php 中,`json_encode()` 默认会省略浮点数末尾的零,且全局 `serialize_precision` 无法为各字段单独设置精度;本文介绍通过 `number_format()` 预处理字段值,实现按需控制每位浮点数的小数位数,并说明其字符串转换本质及使用注意事项。在构建 JSON API 响应时,常需对不同浮点字段施加差异化精度控制------例如地理坐标(latitude/longitude)保留 6~8 位小数以保障定位精度,而高度(height)仅需保留 2 位小数并显式展示 .00。但 PHP 的 json_encode() 本身不支持字段级精度配置,ini_set('serialize_precision', N) 仅影响全局浮点序列化行为,且自 PHP 7.1 起默认为 -1(即完整精度),仍无法满足"同个响应中多精度共存"的需求。正确做法是:在赋值前,对每个浮点字段单独调用 number_format() 进行格式化。该函数接受数值、小数位数、小数点符号和千位分隔符(后两者可省略),返回带指定精度的字符串:response-\>payload-\>latitude = number_format(rad2deg(latitude), 6, '.', ''); // 如 35.123000response-\>payload-\>longitude = number_format(rad2deg(longitude), 6, '.', ''); // 如 41.123500response-\>payload-\>height = number_format(height, 2, '.', ''); // 如 100.00执行 json_encode($response, JSON_PRETTY_PRINT) 后,将输出符合预期的 JSON: 文心快码 文心快码(Comate)是百度推出的一款AI辅助编程工具

相关推荐
哆哆啦009 分钟前
使用 Obsidian + GitHub Actions + GitHub Pages 搭建内容发布流
数据库·笔记·github·obsidian
duke86926721412 分钟前
PostgreSQL 中高效插入多对多关联数据的三种方案对比与最佳实践
jvm·数据库·python
迷枫71216 分钟前
达梦数据库备份还原:物理备份、逻辑备份
数据库
czlczl2002092520 分钟前
mysql表复制方案
数据库·mysql
狮子座明仔25 分钟前
AgentSPEX:当 Agent 框架开始把“控制流“从 Python 里抠出来
开发语言·python
m0_4636722029 分钟前
mysql数据库如何进行逻辑备份与物理备份对比_优缺点分析
jvm·数据库·python
2401_8676239834 分钟前
SQL如何进行分组后字符串拼接_使用GROUP_CONCAT或STRING_AGG
jvm·数据库·python
kexnjdcncnxjs36 分钟前
MySQL触发器无法触发的原因分析_MySQL触发器排查指南
jvm·数据库·python
Java后端的Ai之路43 分钟前
CodeBuddy-Rules配置
人工智能·python·ai编程
拾-光1 小时前
【Git】命令大全:从入门到高手,100 个最常用命令速查(2026 版)
java·大数据·人工智能·git·python·elasticsearch·设计模式