17370845950

Java开发个人日记管理程序_文件持久化与格式化输出实现
使用JSON序列化与文件IO实现日记持久化,通过BufferedReader/Writer读写文本文件,每篇日记以JSON格式存储并逐行解析;程序启动时加载文件内容反序列化为对象列表,结合Gson库完成数据转换;为提升可读性,设计标题居中、日期右对齐、正文自动换行及分隔线的格式化输出方案,确保信息清晰美观。

开发一个Java个人日记管理程序时,核心需求之一是实现文件持久化格式化输出。用户希望写下的每一篇日记都能安全保存,并能以清晰、美观的方式查看。本文记录我在实现这两个功能过程中的思路与关键代码。

日记数据的文件持久化

为了让日记在程序关闭后仍能保留,必须将数据写入本地文件。我选择使用Java的BufferedWriterBufferedReader来操作文本文件,每篇日记独立成行存储,采用JSON格式序列化对象,便于读取和解析。

日记条目类结构如下:

class DiaryEntry {
    private String title;
    private String content;
    private String date;

    // 构造方法、getter/setter省略
}

保存日记时,将每个DiaryEntry转换为JSON字符串写入文件:

  • 使用new BufferedWriter(new FileWriter("diaries.txt", true))打开文件并追加内
  • 调用Gson.toJson(entry)将对象转为JSON字符串(需引入Gson库)
  • 每次写入后换行,便于逐行读取

从文件加载日记列表

程序启动时需要还原已保存的日记。通过BufferedReader逐行读取文件内容,再用Gson反序列化为DiaryEntry对象。

  • 使用Files.lines(Paths.get("diaries.txt"))流式读取所有行(适用于小文件)
  • 对每一行执行gson.fromJson(line, DiaryEntry.class)
  • 将结果添加到ArrayList中供后续展示

异常处理必不可少:若文件不存在或内容损坏,应提示用户并返回空列表,避免程序崩溃。

格式化输出提升可读性

直接打印JSON内容不利于阅读。为此我设计了美观的控制台输出格式:

  • 标题居中显示,用等号包围,如:=== 今日总结 ===
  • 日期右对齐,使用String.format("%40s", date)控制位置
  • 正文每行不超过60字符,自动换行,增强阅读体验
  • 条目之间插入分隔线(如"────────────────────")区分不同日记

示例输出:

=== 工作复盘 ===
2025-04-05
今天完成了项目模块重构,优化了数据加载速度...
───────────────────────────────────────────────

小结

通过结合JSON序列化与文件IO,实现了日记的可靠存储与读取。格式化输出则让信息呈现更友好。后续可扩展支持Markdown渲染或导出HTML功能。基本上就这些,不复杂但容易忽略细节。