Java GUI记账本(基于Mysql&&文件存储两种版本)
*/
* Copyright (c) 2016,烟台大学计算机与控制工程学院
* All rights reserved.
* 文件名:text.java
* 作者:常轩
* 微信公众号:Worldhello
* 完成日期:2016年12月27日
* 版本号:V1.0
* 程序输入:无
* 程序输出:见运行结果
*/
--------------------------------------------
>>> 现已有基于Mysql数据库版本的记账本,详情点击 记账本(数据库版本)查看
>>> 基于文件存储的记账本,详情点击 记账本(文件存储)查看
-------------------------------------------- /*
功能概述:
记录个人的收入和支出,自动记录时间。图形界面,需要先进行注册再登陆,登陆不同的账号记录不同的收支情况,极大的保护了个人的隐私,等。
因为本程序中需要用到一些图片资源,只是上传部分代码(代码也不太全,仅供参考),如需获取整个项目的代码和资源,请关注微信众号:Worldhello 后台回复:记账本 即可获得完整项目的压缩包
*/ package com.ytcx.ui;
import java.awt.*;
import java.awt.event.ComponentAdapter;
import java.awt.event.ComponentEvent;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Vector; import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JSplitPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.JFrame.*;
import javax.swing.table.DefaultTableModel; import com.ytcx.server.Operation;
import com.ytcx.util.Tool;
public class UserWindow extends JFrame{
private final String str=null;
private String fileStr=null;
Operation oper=null; private JTable table=new JTable();
private DefaultTableModel dtm=new DefaultTableModel();
Vector colName=new Vector();
private JComboBox typeCom=new JComboBox();
private JTextField moneyTxt=new JTextField();
private JTextField remarkTxt=new JTextField();
private String id;
private String time;
public UserWindow(String str,String fileStr){ this.fileStr=fileStr;
oper=new Operation(fileStr);
setTitle("欢迎用户"+str+"使用记账本");
this.setIconImage(new ImageIcon("note.png").getImage());
setBounds(50,50,900,600);
init();
setVisible(true);
}
void init(){
JScrollPane sp=new JScrollPane(setTable());
final JSplitPane jsp=new JSplitPane(JSplitPane.VERTICAL_SPLIT,sp,setInfo());
jsp.addComponentListener(new ComponentAdapter(){
public void componentResized(ComponentEvent e){
jsp.setDividerLocation(0.5);
}
});
this.add(jsp);
//showUserImage=new ImageIcon(this.getClass().getResource("notes.png")); } public JTable setTable(){ colName.add("流水号");
colName.add("类型");
colName.add("金额");
colName.add("日期");
colName.add("备注");
Vector data=oper.select();
dtm.setDataVector(data, colName);
table.setModel(dtm); table.addMouseListener(new MouseListener(){
public void mouseClicked(MouseEvent arg0) {
int row=table.getSelectedRow();
id=dtm.getValueAt(row, 0).toString();
//测试语句System.out.println(id);
String type=dtm.getValueAt(row, 1).toString();
String money=dtm.getValueAt(row, 2).toString();
String remark=dtm.getValueAt(row, 4).toString();
typeCom.setSelectedItem(type);
moneyTxt.setText(money);
remarkTxt.setText(remark);
time=dtm.getValueAt(row, 3).toString();
}
@Override
public void mouseEntered(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseExited(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mousePressed(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseReleased(MouseEvent arg0) {
// TODO Auto-generated method stub }});
return table;
}
/*public static void main(String[] args) {
new UserWindow();
}*/
public JPanel setInfo(){
JPanel jp=new JPanel();
jp.setLayout(null); JLabel label1=new JLabel("类型");
label1.setBounds(20, 50, 50, 30);
jp.add(label1);
typeCom.addItem("收入");
typeCom.addItem("支出");
typeCom.setBounds(80,50,60,30); JLabel label2=new JLabel("金额");
label2.setBounds(200,50,50,30);
jp.add(label2);
moneyTxt.setBounds(250,50,100,30); JLabel label3=new JLabel("备注");
label3.setBounds(380,50,50,30);
jp.add(label3);
remarkTxt.setBounds(420,50,100,30); JButton button1=new JButton("修改");
button1.setBounds(50, 100, 100, 50);
button1.addMouseListener(new MouseListener(){ @Override
public void mouseClicked(MouseEvent arg0) {
String type=typeCom.getSelectedItem().toString();
String money=moneyTxt.getText();
String remark=remarkTxt.getText();
Tool tool=new Tool();
String time=tool.getTime();
oper.update(id, type, money, time, remark);
/*
* 表格刷新
*/
Vector dataSel=oper.select();
dtm.setDataVector(dataSel, colName);
table.setModel(dtm);
} @Override
public void mouseEntered(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseExited(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mousePressed(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseReleased(MouseEvent arg0) {
// TODO Auto-generated method stub }}); JButton button2=new JButton("增加");
button2.setBounds(150, 100, 100, 50);
button2.addMouseListener(new MouseListener(){ @Override
public void mouseClicked(MouseEvent arg0) {
String type=typeCom.getSelectedItem().toString();
String money=moneyTxt.getText();
String remark=remarkTxt.getText();
Tool tool=new Tool();
int id=tool.getNewId();
String time=tool.getTime();
String data=id+" "+type+" "+money+" "+time+" "+remark+"\n";
oper.add(data);
/*
* 表格刷新
*/
Vector dataSel=oper.select();
dtm.setDataVector(dataSel, colName);
table.setModel(dtm);
} @Override
public void mouseEntered(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseExited(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mousePressed(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseReleased(MouseEvent arg0) {
// TODO Auto-generated method stub } });
JButton button3=new JButton("删除");
button3.setBounds(250, 100, 100, 50);
button3.addMouseListener(new MouseListener(){ @Override
public void mouseClicked(MouseEvent arg0) {
oper.delete(id);
/*
* 表格刷新
*/ Vector dataSel=oper.select();
dtm.setDataVector(dataSel, colName);
table.setModel(dtm);
} @Override
public void mouseEntered(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseExited(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mousePressed(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseReleased(MouseEvent arg0) {
// TODO Auto-generated method stub } }); jp.add(remarkTxt);
jp.add(moneyTxt);
jp.add(typeCom);
jp.add(button1);
jp.add(button2);
jp.add(button3);
return jp;
}
} package com.ytcx.ui;
import java.awt.*;
import java.awt.event.ComponentAdapter;
import java.awt.event.ComponentEvent;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Vector; import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JSplitPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.JFrame.*;
import javax.swing.table.DefaultTableModel; import com.ytcx.server.Operation;
import com.ytcx.util.Tool;
public class UserWindow extends JFrame{
private final String str=null;
private String fileStr=null;
Operation oper=null; private JTable table=new JTable();
private DefaultTableModel dtm=new DefaultTableModel();
Vector colName=new Vector();
private JComboBox typeCom=new JComboBox();
private JTextField moneyTxt=new JTextField();
private JTextField remarkTxt=new JTextField();
private String id;
private String time;
public UserWindow(String str,String fileStr){ this.fileStr=fileStr;
oper=new Operation(fileStr);
setTitle("欢迎用户"+str+"使用记账本");
this.setIconImage(new ImageIcon("note.png").getImage());
setBounds(50,50,900,600);
init();
setVisible(true);
}
void init(){
JScrollPane sp=new JScrollPane(setTable());
final JSplitPane jsp=new JSplitPane(JSplitPane.VERTICAL_SPLIT,sp,setInfo());
jsp.addComponentListener(new ComponentAdapter(){
public void componentResized(ComponentEvent e){
jsp.setDividerLocation(0.5);
}
});
this.add(jsp);
//showUserImage=new ImageIcon(this.getClass().getResource("notes.png")); } public JTable setTable(){ colName.add("流水号");
colName.add("类型");
colName.add("金额");
colName.add("日期");
colName.add("备注");
Vector data=oper.select();
dtm.setDataVector(data, colName);
table.setModel(dtm); table.addMouseListener(new MouseListener(){
public void mouseClicked(MouseEvent arg0) {
int row=table.getSelectedRow();
id=dtm.getValueAt(row, 0).toString();
//测试语句System.out.println(id);
String type=dtm.getValueAt(row, 1).toString();
String money=dtm.getValueAt(row, 2).toString();
String remark=dtm.getValueAt(row, 4).toString();
typeCom.setSelectedItem(type);
moneyTxt.setText(money);
remarkTxt.setText(remark);
time=dtm.getValueAt(row, 3).toString();
}
@Override
public void mouseEntered(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseExited(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mousePressed(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseReleased(MouseEvent arg0) {
// TODO Auto-generated method stub }});
return table;
}
/*public static void main(String[] args) {
new UserWindow();
}*/
public JPanel setInfo(){
JPanel jp=new JPanel();
jp.setLayout(null); JLabel label1=new JLabel("类型");
label1.setBounds(20, 50, 50, 30);
jp.add(label1);
typeCom.addItem("收入");
typeCom.addItem("支出");
typeCom.setBounds(80,50,60,30); JLabel label2=new JLabel("金额");
label2.setBounds(200,50,50,30);
jp.add(label2);
moneyTxt.setBounds(250,50,100,30); JLabel label3=new JLabel("备注");
label3.setBounds(380,50,50,30);
jp.add(label3);
remarkTxt.setBounds(420,50,100,30); JButton button1=new JButton("修改");
button1.setBounds(50, 100, 100, 50);
button1.addMouseListener(new MouseListener(){ @Override
public void mouseClicked(MouseEvent arg0) {
String type=typeCom.getSelectedItem().toString();
String money=moneyTxt.getText();
String remark=remarkTxt.getText();
Tool tool=new Tool();
String time=tool.getTime();
oper.update(id, type, money, time, remark);
/*
* 表格刷新
*/
Vector dataSel=oper.select();
dtm.setDataVector(dataSel, colName);
table.setModel(dtm);
} @Override
public void mouseEntered(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseExited(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mousePressed(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseReleased(MouseEvent arg0) {
// TODO Auto-generated method stub }}); JButton button2=new JButton("增加");
button2.setBounds(150, 100, 100, 50);
button2.addMouseListener(new MouseListener(){ @Override
public void mouseClicked(MouseEvent arg0) {
String type=typeCom.getSelectedItem().toString();
String money=moneyTxt.getText();
String remark=remarkTxt.getText();
Tool tool=new Tool();
int id=tool.getNewId();
String time=tool.getTime();
String data=id+" "+type+" "+money+" "+time+" "+remark+"\n";
oper.add(data);
/*
* 表格刷新
*/
Vector dataSel=oper.select();
dtm.setDataVector(dataSel, colName);
table.setModel(dtm);
} @Override
public void mouseEntered(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseExited(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mousePressed(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseReleased(MouseEvent arg0) {
// TODO Auto-generated method stub } });
JButton button3=new JButton("删除");
button3.setBounds(250, 100, 100, 50);
button3.addMouseListener(new MouseListener(){ @Override
public void mouseClicked(MouseEvent arg0) {
oper.delete(id);
/*
* 表格刷新
*/ Vector dataSel=oper.select();
dtm.setDataVector(dataSel, colName);
table.setModel(dtm);
} @Override
public void mouseEntered(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseExited(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mousePressed(MouseEvent arg0) {
// TODO Auto-generated method stub } @Override
public void mouseReleased(MouseEvent arg0) {
// TODO Auto-generated method stub } }); jp.add(remarkTxt);
jp.add(moneyTxt);
jp.add(typeCom);
jp.add(button1);
jp.add(button2);
jp.add(button3);
return jp;
}
} package com.ytcx.server; import java.util.Vector; import com.ytcx.io.FileIO;
import com.ytcx.io.FileIOImp;
import com.ytcx.util.Tool; public class Operation {
FileIO io=new FileIOImp();
Tool tool=new Tool();
public Operation(String filename){
io.checkFile(filename);
}
public Vector select() {
String data=io.read();
//System.out.println("lala,看看进来执行没有?"); 测试语句
return tool.StringToVec(data);
// TODO Auto-generated method stub } public void add(String data){
io.write(data, true);
} public void delete(String id){
Vector vecBig=select();
//System.out.println("删除了没有?"); //测试
for(int i=0;i<vecBig.size();i++){
Vector vecSmall=(Vector)vecBig.get(i);
//测试语句System.out.println("+1");
if(vecSmall.get(0).toString().equals(id)){
vecBig.remove(i);
// System.out.println("理论上已经删除"); //测试
break;
} }
String data=tool.VecToString(vecBig);
io.write(data, false);
}
public void update(String id,String type,String money,String time,String remark){
Vector vecBig =select();
for(int i=0;i<vecBig.size();i++){
Vector vecSmall=(Vector)vecBig.get(i);
if(vecSmall.get(0).toString().equals(id)){
vecSmall.removeAllElements();
vecSmall.add(id);
vecSmall.add(type);
vecSmall.add(money);
vecSmall.add(time);
vecSmall.add(remark);
break;
}
}
String data=tool.VecToString(vecBig);
io.write(data, false);
} } 运行图片:
Java GUI记账本(基于Mysql&&文件存储两种版本)的更多相关文章
- MySQL命令执行sql文件的两种方法
MySQL命令执行sql文件的两种方法 摘要:和其他数据库一样,MySQL也提供了命令执行sql脚本文件,方便地进行数据库.表以及数据等各种操作.下面笔者讲解MySQL执行sql文件命令的两种方法,希 ...
- Eclipse将引用了第三方jar包的Java项目打包成jar文件的两种方法
方案一:用Eclipse自带的Export功能 步骤1:准备主清单文件 “MANIFEST.MF”, 由于是打包引用了第三方jar包的Java项目,故需要自定义配置文件MANIFEST.MF,在该项目 ...
- 将引用了第三方jar包的Java项目打包成jar文件的两种方法
方案一:用Eclipse自带的Export功能 步骤1:准备主清单文件 “MANIFEST.MF”, 由于是打包引用了第三方jar包的Java项目,故需要自定义配置文件MANIFEST.MF,在该项目 ...
- MySQL中的两种临时表
MySQL中的两种临时表 伯乐在线2016-07-06 05:16:52阅读(4556)评论(3) 声明:本文由入驻搜狐公众平台的作者撰写,除搜狐官方账号外,观点仅代表作者本人,不代表搜狐立场.举报 ...
- elf格式转换为hex格式文件的两种方法
这周工作终于不太忙了,可以写点笔记总结一下了. 之前的文章如何在Keil-MDK开发环境生成Bin格式文件,介绍了如何在Keil开发环境使用fromelf软件,将生成的axf文件转换为bin文件,这次 ...
- (转载)Eclipse将引用了第三方jar包的Java项目打包成可执行jar的两种方法
转载自:http://www.cnblogs.com/lanxuezaipiao/p/3291641.html 方案一:用Eclipse自带的Export功能 步骤1:准备主清单文件 "MA ...
- C++连接mysql数据库的两种方法
本文主要介绍了C++连接mysql数据库的两种方法,希望通过本文,能对你有所帮助,一起来看. 现在正做一个接口,通过不同的连接字符串操作不同的数据库.要用到mysql数据库,以前没用过这个数据库,用a ...
- linux安装mysql服务分两种安装方法:
linux安装mysql服务分两种安装方法: ①源码安装,优点是安装包比较小,只有十多M,缺点是安装依赖的库多,安装编译时间长,安装步骤复杂容易出错: ②使用官方编译好的二进制文件安装,优点是安装速度 ...
- Eclipse项目中引用第三方jar包时将项目打包成jar文件的两种方式
转载自:http://www.cnblogs.com/lanxuezaipiao/p/3291641.html 方案一:用Eclipse自带的Export功能 步骤1:准备主清单文件 “MANIFES ...
随机推荐
- Papa开启“点播孙子”模式,新型老年人服务能在国内扎根吗?
"互联网+"对多个行业的全面赋能和渗入,的确让我们的生活与工作处处充满了便利.很多"跑断腿"才能办的事,现在只要在PC.智能手机上滑动鼠标.点击屏幕就能轻松搞定 ...
- POJ-2528 Mayor's posters(线段树区间更新+离散化)
http://poj.org/problem?id=2528 https://www.luogu.org/problem/UVA10587 Description The citizens of By ...
- AC和路由器
无线AC控制器是一种网络设备,比如我曾接触过的丰润达的AC100和AC180等,用它们可以来集中控制和管理无线AP,比如下发配置.修改相关配置参数.射频智能管理.接入安全控制等. 路由器是一种连接多个 ...
- 极简配置,业务上云只需 3min
为了简化账号配置环节,实现本地一键开发部署,Serverless Framework 发布了微信扫码一键登录能力,支持用户在 Serverless Framework 环境扫码注册登陆,用户无需登录控 ...
- 项目中spring容器加载的问题
今天做一个项目采用的是传统架构,没有采用分布式,部署时出现了异常,信息是: org.springframework.beans.factory.NoSuchBeanDefinitionExceptio ...
- FPGA浮点数定点数的处理
http://blog.chinaaet.com/justlxy/p/5100053166大佬博客,讲的非常有条理的 1,基础知识 (1)定点数的基础认知: 首先例如一个16位的数表示的定点数的范围是 ...
- flink分层 api
最底层的processFunction 功能强大,使用复杂 中间层的DataSet api map reduce ...一些基本运算api 中上层的tableAPI 最上层 SQL 两个相似,只是写法 ...
- java学习——反射机制
/* * JAVA反射机制是在运行状态中,对于任意一个类 (class文件),都能够知道这个类的所有属性和方法: * 对于任意一个对象,都能够调用它的任意一个方法和属性: * 这种动态获取的信息以及动 ...
- LeetCode Day 8
LeetCode0015 给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?找出所有满足条件且不重复的三元组. 例如, 给 ...
- fastdfs+nginx make时报错fatal error:fdfs_define.h: 没有那个文件或目录
环境: ubuntu 18.04.1 fastdfs-nginx-module_v1.16 root@wang-machine:~/桌面/FastDFS# cd nginx-1.8.1/root@wa ...