0

0

如何在Java中开发记账本应用

P粉602998670

P粉602998670

发布时间:2025-09-26 19:21:01

|

572人浏览过

|

来源于php中文网

原创

答案:该文章介绍了用java开发记账本应用的完整流程,涵盖功能设计、数据模型构建、核心管理类实现、文件持久化及用户交互。1. 定义record类封装收支记录;2. 创建ledger类实现添加、查看、统计和保存功能;3. 使用bufferedwriter/reader将数据以csv格式存取;4. 主程序通过scanner提供菜单式控制台交互;5. 程序启动时加载ledger.csv历史数据,退出时自动保存。此项目帮助掌握面向对象编程与基础io操作,适合初学者进阶练习。

如何在java中开发记账本应用

开发一个记账本应用在Java中是一个非常适合初学者到中级开发者练手的项目。它能帮助你掌握面向对象编程、文件读写、集合操作以及简单的用户交互设计。下面从结构设计到功能实现,一步步说明如何用Java开发一个基础但实用的记账本应用。

1. 明确核心功能

一个基本的记账本应具备以下功能:

  • 记录收支条目:包括金额、类型(收入/支出)、分类(餐饮、交通、工资等)、备注和时间
  • 查看所有记录:按时间顺序列出所有账目
  • 统计信息:计算总收入、总支出、当前余额
  • 数据持久化:将数据保存到文件,重启程序后仍可读取
  • 简单交互界面:通过控制台输入命令进行操作

2. 设计数据模型类

使用面向对象思想,先定义账目条目的类。

public class Record {
    private double amount;
    private String type; // "收入" 或 "支出"
    private String category;
    private String remark;
    private String date;
<pre class='brush:java;toolbar:false;'>public Record(double amount, String type, String category, String remark, String date) {
    this.amount = amount;
    this.type = type;
    this.category = category;
    this.remark = remark;
    this.date = date;
}

// Getter 和 Setter 方法(可自动生成)
@Override
public String toString() {
    return date + " | " + type + " | " + category + " | ¥" + amount + " | " + remark;
}

}

立即学习Java免费学习笔记(深入)”;

8CMS企业网站管理系统 X1.0
8CMS企业网站管理系统 X1.0

8CMS网站管理系统 (著作权登记号 2009SRBJ3516 ),基于微软 asp + Access 开发,是实用的双模建站系统,应用于企业宣传型网站创建、贸易型网站创建、在线购买商务型网站创建。是中小型企业能够以最低的成本、最少的人力投入、在最短的时间内架设一个功能齐全、性能优异、SEO架构合理的网站平台工具。8CMS的使命是把建设网站最大程度的简化。

下载

3. 实现核心管理类

创建一个记账本管理器,负责添加、查询、统计和保存数据。

import java.util.*;
<p>public class Ledger {
private List<Record> records;
private Scanner scanner;</p><pre class='brush:java;toolbar:false;'>public Ledger() {
    records = new ArrayList<>();
    scanner = new Scanner(System.in);
}

public void addRecord() {
    System.out.print("金额: ");
    double amount = scanner.nextDouble();
    System.out.print("类型(收入/支出): ");
    String type = scanner.next();
    System.out.print("分类: ");
    String category = scanner.next();
    System.out.print("备注: ");
    String remark = scanner.next();
    String date = new Date().toString();

    records.add(new Record(amount, type, category, remark, date));
    System.out.println("记录已添加!");
}

public void viewRecords() {
    if (records.isEmpty()) {
        System.out.println("暂无记录。");
        return;
    }
    for (Record r : records) {
        System.out.println(r);
    }
}

public void showSummary() {
    double income = 0, expense = 0;
    for (Record r : records) {
        if ("收入".equals(r.getType())) {
            income += r.getAmount();
        } else if ("支出".equals(r.getType())) {
            expense += r.getAmount();
        }
    }
    System.out.println("总收入: ¥" + income);
    System.out.println("总支出: ¥" + expense);
    System.out.println("余额: ¥" + (income - expense));
}

}

立即学习Java免费学习笔记(深入)”;

4. 数据保存与加载(使用文本文件)

利用Java的文件IO功能,将记录保存为CSV格式,便于查看和恢复。

可以使用BufferedWriter写入,BufferedReader读取。每行代表一条记录,字段用逗号分隔。

import java.io.*;
<p>// 保存数据到文件
public void saveToFile(String filename) throws IOException {
try (BufferedWriter writer = new BufferedWriter(new FileWriter(filename))) {
for (Record r : records) {
writer.write(String.join(",", 
r.getAmount()+"", r.getType(), r.getCategory(), r.getRemark(), r.getDate()));
writer.newLine();
}
}
}</p><p>// 从文件加载数据
public void loadFromFile(String filename) throws IOException {
File file = new File(filename);
if (!file.exists()) return;</p><pre class='brush:java;toolbar:false;'>try (BufferedReader reader = new BufferedReader(new FileReader(file))) {
    String line;
    while ((line = reader.readLine()) != null) {
        String[] parts = line.split(",");
        if (parts.length == 5) {
            Record r = new Record(
                Double.parseDouble(parts[0]),
                parts[1], parts[2], parts[3], parts[4]
            );
            records.add(r);
        }
    }
}

}

立即学习Java免费学习笔记(深入)”;

5. 主程序与用户交互

在main方法中构建循环菜单,让用户选择操作。

public static void main(String[] args) {
    Ledger ledger = new Ledger();
<pre class='brush:java;toolbar:false;'>try {
    ledger.loadFromFile("ledger.csv");
} catch (IOException e) {
    System.out.println("无法加载历史数据:" + e.getMessage());
}

Scanner scanner = new Scanner(System.in);
while (true) {
    System.out.println("\n--- 记账本 ---");
    System.out.println("1. 添加记录");
    System.out.println("2. 查看所有记录");
    System.out.println("3. 查看统计");
    System.out.println("4. 保存并退出");
    System.out.print("请选择: ");

    int choice = scanner.nextInt();
    switch (choice) {
        case 1 -> ledger.addRecord();
        case 2 -> ledger.viewRecords();
        case 3 -> ledger.showSummary();
        case 4 -> {
            try {
                ledger.saveToFile("ledger.csv");
                System.out.println("数据已保存,再见!");
            } catch (IOException e) {
                System.out.println("保存失败:" + e.getMessage());
            }
            return;
        }
        default -> System.out.println("无效选择,请重试。");
    }
}

}

立即学习Java免费学习笔记(深入)”;

基本上就这些。这个记账本虽然运行在控制台,但已经具备了完整的核心逻辑。后续你可以扩展功能,比如支持按月份筛选、图形界面(Swing/JavaFX)、数据库存储(SQLite)或导出Excel报表。关键是先把基础打牢,理解类的设计与数据流的处理方式。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

58

2025.09.05

java面向对象
java面向对象

本专题整合了java面向对象相关内容,阅读专题下面的文章了解更多详细内容。

63

2025.11.27

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

384

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2110

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

357

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

259

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

329

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

420

2023.10.16

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

22

2026.03.10

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 20.9万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.6万人学习

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

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