0

0

将嵌套对象数组转换为标准化键值对数组的完整教程

心靈之曲

心靈之曲

发布时间:2026-01-02 20:51:08

|

540人浏览过

|

来源于php中文网

原创

将嵌套对象数组转换为标准化键值对数组的完整教程

本文介绍如何将嵌套对象数组转换为标准化键值对数组的完整教程。本文介绍如何将包含日期字符串为键、数值为值的对象数组,高效转换为每个元素都具有统一 `date` 和 `count` 字段的对象数组,并支持保留嵌套结构或展平为一维数组。

在实际数据处理中,我们常遇到形如 [{ '2023-06-02': 2, '2023-06-21': 6 }, { '2023-06-29': 2, '2023-06-23': 1 }] 的数据结构——即数组中每个元素都是一个以日期为键、计数为值的扁平对象。但前端可视化(如图表库)或后端 API 通常要求结构化、字段统一的数据格式,例如 [{ date: '2023-06-02', count: '2' }, ...]。

此时,可借助 Object.entries() + map() 组合实现精准转换:

✅ 核心转换逻辑(保持二维结构)

const arrayWithDates = [
  { '2023-06-02': 2, '2023-06-21': 6 },
  { '2023-06-29': 2, '2023-06-23': 1 }
];

const arrayTransformed = arrayWithDates.map(record =>
  Object.entries(record).map(([date, count]) => ({
    count: String(count), // 强制转为字符串,匹配目标格式
    date
  }))
);

console.log(arrayTransformed);
// 输出:[[{count:"2",date:"2023-06-02"},{count:"6",date:"2023-06-21"}], ...]

? 可选:展平为一维数组(适用于聚合渲染场景)

若需所有日期-计数对合并为单层数组(如绘制时间序列折线图),追加 .flat() 即可:

Flowith
Flowith

一款GPT4驱动的节点式 AI 创作工具

下载
const flatTransformed = arrayWithDates
  .map(record => 
    Object.entries(record).map(([date, count]) => ({
      count: String(count),
      date
    }))
  )
  .flat();

console.log(flatTransformed);
// 输出:[{count:"2",date:"2023-06-02"}, {count:"6",date:"2023-06-21"}, ...]

⚠️ 注意事项

  • 键名合法性:原始对象键含连字符(如 '2023-06-02')是合法的字符串键,无需额外引号(但定义时建议加引号避免语法歧义);
  • 类型处理:count 值默认为数字,使用 String(count) 确保输出与示例一致;如需保留数字类型,可直接写 count;
  • 空对象/边界情况:若某对象为空({}),Object.entries() 返回 [],map 后生成空数组 [],逻辑安全,无需额外校验;
  • 性能提示:该方案为纯函数式、无副作用,适用于任意长度数组,时间复杂度 O(n×m),其中 n 是外层数组长度,m 是各对象平均键数量。

掌握此模式后,你可轻松适配类似需求:如将 { apple: 5, banana: 3 } → [{ name: 'apple', value: 5 }, ...],只需调整解构变量名与返回字段即可。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

312

2023.08.02

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

193

2023.11.20

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

251

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

206

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1436

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

609

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

547

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

539

2024.04.29

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 7.8万人学习

CSS3 教程
CSS3 教程

共18课时 | 4.2万人学习

Vue 教程
Vue 教程

共42课时 | 5.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号