*/
* 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&&文件存储两种版本)的更多相关文章

  1. MySQL命令执行sql文件的两种方法

    MySQL命令执行sql文件的两种方法 摘要:和其他数据库一样,MySQL也提供了命令执行sql脚本文件,方便地进行数据库.表以及数据等各种操作.下面笔者讲解MySQL执行sql文件命令的两种方法,希 ...

  2. Eclipse将引用了第三方jar包的Java项目打包成jar文件的两种方法

    方案一:用Eclipse自带的Export功能 步骤1:准备主清单文件 “MANIFEST.MF”, 由于是打包引用了第三方jar包的Java项目,故需要自定义配置文件MANIFEST.MF,在该项目 ...

  3. 将引用了第三方jar包的Java项目打包成jar文件的两种方法

    方案一:用Eclipse自带的Export功能 步骤1:准备主清单文件 “MANIFEST.MF”, 由于是打包引用了第三方jar包的Java项目,故需要自定义配置文件MANIFEST.MF,在该项目 ...

  4. MySQL中的两种临时表

    MySQL中的两种临时表 伯乐在线2016-07-06 05:16:52阅读(4556)评论(3) 声明:本文由入驻搜狐公众平台的作者撰写,除搜狐官方账号外,观点仅代表作者本人,不代表搜狐立场.举报 ...

  5. elf格式转换为hex格式文件的两种方法

    这周工作终于不太忙了,可以写点笔记总结一下了. 之前的文章如何在Keil-MDK开发环境生成Bin格式文件,介绍了如何在Keil开发环境使用fromelf软件,将生成的axf文件转换为bin文件,这次 ...

  6. (转载)Eclipse将引用了第三方jar包的Java项目打包成可执行jar的两种方法

    转载自:http://www.cnblogs.com/lanxuezaipiao/p/3291641.html 方案一:用Eclipse自带的Export功能 步骤1:准备主清单文件 "MA ...

  7. C++连接mysql数据库的两种方法

    本文主要介绍了C++连接mysql数据库的两种方法,希望通过本文,能对你有所帮助,一起来看. 现在正做一个接口,通过不同的连接字符串操作不同的数据库.要用到mysql数据库,以前没用过这个数据库,用a ...

  8. linux安装mysql服务分两种安装方法:

    linux安装mysql服务分两种安装方法: ①源码安装,优点是安装包比较小,只有十多M,缺点是安装依赖的库多,安装编译时间长,安装步骤复杂容易出错: ②使用官方编译好的二进制文件安装,优点是安装速度 ...

  9. Eclipse项目中引用第三方jar包时将项目打包成jar文件的两种方式

    转载自:http://www.cnblogs.com/lanxuezaipiao/p/3291641.html 方案一:用Eclipse自带的Export功能 步骤1:准备主清单文件 “MANIFES ...

随机推荐

  1. 吴裕雄--天生自然 JAVA开发学习:数据结构

    import java.util.Vector; import java.util.Enumeration; public class EnumerationTester { public stati ...

  2. python学习——函数返回值及递归

    返回值 return语句是从python 函数返回一个值,在讲到定义函数的时候有讲过,每个函数都要有一个返回值.Python中的return语句有什么作用,今天小编就依目前所了解的讲解一下.pytho ...

  3. 可用的 .net core 支持 RSA 私钥加密工具类

    首先说明 MS并不建议私钥加密,而且.net 于安全的考虑,RSACryptoServiceProvider类解密时只有同时拥有公钥和私钥才可以,原因是公钥是公开的,会被多人持有,这样的数据传输是不安 ...

  4. 存储过程获取QLIKVIEW关键数据

    declare @table table(DDID INT,FHDID INT ,CKDID INT,ZGYSDID INT,CWYSDID INT)--定义表变量来存放存储过程返回的内容insert ...

  5. python爬虫和数据分析、数据挖掘

    一.python爬虫脑图: 二.python爬虫流程: 三.python数据分析简介 四.python数据预处理方法 五.python数据挖掘 六.数据探索基础

  6. maven-assembly-plugin 打包包含多余依赖问题一则

    有同事反馈自己maven-assembly-plugin打的包里面多了很多mvn dependency:tree中没有的jar. 我当时只是试着把他的maven-assembly-plugin更新到了 ...

  7. 83)PHP,配置文件功能

    首选配置文件应该在  我们的应用application目录中,这样针对每一应用,都有自己的配置文件. 我觉得配置文件的名字很有意思,首先是  名字.config.php 格式就是 return arr ...

  8. cs231n spring 2017 lecture3 Loss Functions and Optimization

    1. Loss function是用来量化评估当前预测的好坏,loss function越小表明预测越好. 几种典型的loss function: 1)Multiclass SVM loss:一般的S ...

  9. isdigital()函数

    函数说明: 主要用于检查其参数是否为十进制数字字符. 头文件: C——#include<ctype.h> C++——#include<cctype> 函数定义:  int is ...

  10. Oracle 10G 服务端的升级

    第一步:备份 rman target / backup full database plus archivelog; 第二步:升级 解压升级包到soft目录下,修改所有者 chown -R oracl ...