横表转竖表的 Java 实现

在数据处理和分析中,表格的转化是一个常见的需求。横表转竖表(也叫数据透视)能够让我们更方便地分析和比较数据。本文将介绍如何在 Java 中实现横表转竖表的转换,同时附带代码示例和图表展示,帮助你更好地理解这个过程。

什么是横表和竖表

横表(宽形式)是传统的数据表示方式,通常表头包含多个字段,每一行代表一个记录。例如,某学生的成绩记录如下:

学生姓名 数学 英语 物理
Alice 90 85 80
Bob 85 80 90

竖表(长形式)则将同一列中的不同属性拆分到多行中,方便数据的处理和分析。上述横表在转换为竖表后应如下所示:

学生姓名 科目 分数
Alice 数学 90
Alice 英语 85
Alice 物理 80
Bob 数学 85
Bob 英语 80
Bob 物理 90

Java 实现

我们可以通过 Java 的集合类和流式操作来实现这个转换。以下是一个简单的示例代码,演示如何将横表数据转换为竖表数据。

import java.util.*;

public class PivotTable {
    public static void main(String[] args) {
        // 原始横表数据
        List<Map<String, Object>> horizontalData = Arrays.asList(
            createRecord("Alice", 90, 85, 80),
            createRecord("Bob", 85, 80, 90)
        );

        // 转换为竖表数据
        List<Map<String, Object>> verticalData = convertToVertical(horizontalData);

        // 输出竖表数据
        verticalData.forEach(System.out::println);
    }

    private static Map<String, Object> createRecord(String name, int math, int english, int physics) {
        Map<String, Object> record = new HashMap<>();
        record.put("学生姓名", name);
        record.put("数学", math);
        record.put("英语", english);
        record.put("物理", physics);
        return record;
    }

    private static List<Map<String, Object>> convertToVertical(List<Map<String, Object>> horizontalData) {
        List<Map<String, Object>> verticalData = new ArrayList<>();
        for (Map<String, Object> record : horizontalData) {
            String studentName = (String) record.get("学生姓名");
            verticalData.add(createVerticalRecord(studentName, "数学", record.get("数学")));
            verticalData.add(createVerticalRecord(studentName, "英语", record.get("英语")));
            verticalData.add(createVerticalRecord(studentName, "物理", record.get("物理")));
        }
        return verticalData;
    }

    private static Map<String, Object> createVerticalRecord(String name, String subject, Object score) {
        Map<String, Object> record = new HashMap<>();
        record.put("学生姓名", name);
        record.put("科目", subject);
        record.put("分数", score);
        return record;
    }
}

代码解析

  1. 数据结构:使用 List<Map<String, Object>> 来存储横表数据。
  2. 转换逻辑:通过循环访问每个学生的记录,将每个科目的分数转化为竖表的形式。
  3. 输出:最终以字典的形式输出每个学生在各科目的成绩。

系统执行流程

接下来,我们通过一个序列图来展示这一过程的执行流。

sequenceDiagram
    participant User as 用户
    participant Data as 数据处理
    User->>Data: 输入横表数据
    Data->>Data: 处理数据
    Data-->>User: 输出竖表数据

项目进度安排

在项目执行过程中,可能会涉及到数据获取、处理和展示的不同阶段。我们可以用甘特图来表示这些阶段。

gantt
    title 项目进度安排
    dateFormat  YYYY-MM-DD
    section 数据获取
    获取数据           :active,  des1, 2023-10-01, 10d
    section 数据处理
    转换为竖表          :         des2, after des1, 5d
    section 数据展示
    输出结果            :         des3, after des2, 3d

结论

横表转竖表是数据处理中的重要技巧,尤其在进行数据分析时,它能够影响数据的理解和判断。通过本篇文章的示例代码和流程图示,希望能帮助你在实际开发中轻松实现这一功能。无论是在数据汇总、可视化还是在报告生成中,掌握这一技能都将大有裨益。今后在面临类似数据转换需求时,希望你能轻松应对,提升数据处理的效率。