0

0

在Java中如何实现个人记账小程序

P粉602998670

P粉602998670

发布时间:2025-10-24 13:36:02

|

458人浏览过

|

来源于php中文网

原创

答案:该Java记账程序通过Record类封装收支记录,AccountBook类管理记录的增删查统与文件持久化,Main类提供命令行交互界面,实现数据自动加载保存。

在java中如何实现个人记账小程序

实现一个简单的个人记账小程序,可以通过面向对象的方式组织代码,结合文件读写来持久化数据。下面是一个基于控制台的Java记账程序的基本实现思路和代码结构。

1. 定义记账条目类(Record)

每一条记账信息可以封装成一个对象,包含日期、金额、类型(收入/支出)、备注等字段。

public class Record {
    private String date;      // 记账日期
    private double amount;    // 金额
    private String type;      // 类型:收入 或 支出
    private String remark;    // 备注
public Record(String date, double amount, String type, String remark) {
    this.date = date;
    this.amount = amount;
    this.type = type;
    this.remark = remark;
}

// Getter 和 Setter 方法
public String getDate() { return date; }
public double getAmount() { return amount; }
public String getType() { return type; }
public String getRemark() { return remark; }

@Override
public String toString() {
    return date + " | " + amount + " | " + type + " | " + remark;
}

}

WeWedding婚纱影楼小程序
WeWedding婚纱影楼小程序

婚纱影楼小程序提供了一个连接用户与影楼的平台,相当于影楼在微信的官网。它能帮助影楼展示拍摄实力,记录访客数据,宣传优惠活动。使用频率高,方便传播,是影楼在微信端宣传营销的得力助手。功能特点:样片页是影楼展示优秀摄影样片提供给用户欣赏并且吸引客户的。套系页是影楼根据市场需求推出的不同套餐,用户可以按照自己的喜好预定套系。个人中心可以查看用户预约的拍摄计划,也可以获取到影楼的联系方式。

下载

2. 实现记账管理类(AccountBook)

这个类负责添加记录、查询记录、统计收支、保存和加载数据。

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

import java.io.*;
import java.util.ArrayList;
import java.util.List;

public class AccountBook { private List records; private static final String FILE_NAME = "account.txt";

public AccountBook() {
    records = new ArrayListzuojiankuohaophpcnyoujiankuohaophpcn();
    loadFromFile();  // 启动时加载已有数据
}

// 添加一条记录
public void addRecord(Record record) {
    records.add(record);
    saveToFile();  // 每次添加后保存
}

// 查看所有记录
public void listAllRecords() {
    if (records.isEmpty()) {
        System.out.println("暂无记账记录。");
        return;
    }
    for (Record r : records) {
        System.out.println(r);
    }
}

// 统计总收入
public double getTotalIncome() {
    return records.stream()
            .filter(r -youjiankuohaophpcn r.getType().equals("收入"))
            .mapToDouble(Record::getAmount)
            .sum();
}

// 统计总支出
public double getTotalExpense() {
    return records.stream()
            .filter(r -youjiankuohaophpcn r.getType().equals("支出"))
            .mapToDouble(Record::getAmount)
            .sum();
}

// 保存到文件
private void saveToFile() {
    try (PrintWriter writer = new PrintWriter(new FileWriter(FILE_NAME))) {
        for (Record r : records) {
            writer.println(r.getDate() + "," + r.getAmount() + "," + r.getType() + "," + r.getRemark());
        }
    } catch (IOException e) {
        System.out.println("保存文件失败:" + e.getMessage());
    }
}

// 从文件加载数据
private void loadFromFile() {
    File file = new File(FILE_NAME);
    if (!file.exists()) return;

    try (BufferedReader reader = new BufferedReader(new FileReader(file))) {
        String line;
        while ((line = reader.readLine()) != null) {
            String[] parts = line.split(",");
            if (parts.length == 4) {
                String date = parts[0];
                double amount = Double.parseDouble(parts[1]);
                String type = parts[2];
                String remark = parts[3];
                records.add(new Record(date, amount, type, remark));
            }
        }
    } catch (IOException | NumberFormatException e) {
        System.out.println("加载数据失败:" + e.getMessage());
    }
}

}

3. 主程序入口(Main)

提供简单的命令行菜单,供用户操作。

import java.util.Scanner;

public class Main { public static void main(String[] args) { AccountBook book = new AccountBook(); 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();
        scanner.nextLine(); // 消费换行符

        switch (choice) {
            case 1:
                System.out.print("日期(如2025-04-05):");
                String date = scanner.nextLine();

                System.out.print("金额:");
                double amount = scanner.nextDouble();
                scanner.nextLine();

                System.out.print("类型(收入/支出):");
                String type = scanner.nextLine();

                System.out.print("备注:");
                String remark = scanner.nextLine();

                book.addRecord(new Record(date, amount, type, remark));
                System.out.println("记录已添加!");
                break;

            case 2:
                book.listAllRecords();
                break;

            case 3:
                System.out.println("总收入:" + book.getTotalIncome());
                System.out.println("总支出:" + book.getTotalExpense());
                System.out.println("结余:" + (book.getTotalIncome() - book.getTotalExpense()));
                break;

            case 4:
                System.out.println("再见!");
                return;

            default:
                System.out.println("无效选择,请重试。");
        }
    }
}

}

4. 运行说明与扩展建议

这个程序运行后会在当前目录生成 account.txt 文件存储数据。每次启动会自动加载历史记录。

可扩展方向:
  • 使用集合框架或数据库(如SQLite)替代文本文件
  • 增加按月份查询功能
  • 加入分类标签(餐饮、交通、工资等)
  • 导出为CSV报表
  • 改为图形界面(Swing/JavaFX)

基本上就这些。不复杂但容易忽略细节,比如异常处理和文件编码问题。初学者可以从这个结构入手,逐步优化功能。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

56

2025.09.05

java面向对象
java面向对象

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

52

2025.11.27

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

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

356

2023.06.29

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

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

2080

2023.08.14

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

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

349

2023.08.31

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

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

256

2023.09.05

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

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

326

2023.10.09

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

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

412

2023.10.16

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

22

2026.01.27

热门下载

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

精品课程

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

共23课时 | 2.9万人学习

C# 教程
C# 教程

共94课时 | 7.8万人学习

Java 教程
Java 教程

共578课时 | 52.3万人学习

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

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