*/
* 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. 吴裕雄--天生自然 pythonTensorFlow图形数据处理:多线程队列操作

    import tensorflow as tf #1. 定义队列及其操作. queue = tf.FIFOQueue(100,"float") enqueue_op = queue ...

  2. day57-mysql-五种约束和sql语句逻辑执行顺序

    二.sql语句逻辑执行顺序 () SELECT () DISTINCT <select_list> 去重复 () FROM <left_table> () <join_t ...

  3. LeetCode No.91,92,93

    No.91 NumDecodings 解码方法 题目 一条包含字母 A-Z 的消息通过以下方式进行了编码: 'A' -> 1 'B' -> 2 ... 'Z' -> 26 给定一个只 ...

  4. python3下scrapy爬虫(第十二卷:解决scrapy数据存储大量数据时阻塞问题)

    之前我们使用scrapy爬取数据,用的存储方式是直接引入PYMYSQL,或者MYSQLDB,案例中数据量并不大,这种数据存储方式属于同步过程,也就是上一条语句执行完才能执行下一条语句,当数据量变大时, ...

  5. MOOC(12) - 安装连接数据库的第三方库

    1.连接数据库需要mysql-python驱动,可以官网下载离线安装包 安装 检查是否导入成功

  6. 限制IP每分钟访问10次

    转载:https://www.jianshu.com/p/d1326ab657ff IP请求限制,之前用过redis的set设置时间戳一分钟过期:也用过nginx的IP限流配置.前者,没法解决“用户在 ...

  7. MSSS攝影大賽計劃書(第三版)

    比賽內容:對香港的城市風景以及自然風光的攝影 預期成果: 提升同學對香港的認識,鼓勵學生走出大學學園去瞭解香港,同時豐富會員的課餘活動,培養同學的興趣愛好 比賽時間:4月1-15日 最後作品提交時間: ...

  8. OpenCV 图像平滑处理

    #include "opencv2/imgproc/imgproc.hpp" #include "opencv2/highgui/highgui.hpp" us ...

  9. JAVA线程笔记。

    继承thread类 并覆写thread类中的run()方法. class 类名称 extents Thread{public void run(){}}实现Runble接口的run方法 线程的star ...

  10. MAVEN实现多环境搭建

    在实际的开发中,会遇到开发环境的不同(开发环境,测试环境,线上环境),会来回根据环境的不同修改配置文件,一不小心修改错误导致无法正常运行,故障排除导致开发效率低.使用maven可以根据环境的不同,自动 ...