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 ...
随机推荐
- 17)PHP,函数基础和参数问题
(1)函数定义形式: function 函数名字(形参1,形参2,形参3........) { 函数体(代码块) } (2)调用形式: 第一种:没有返回值的函数,则调用独立的语句 函数名(实参1,实参 ...
- Windows 常用配置 - 启用长路径
Windows 启用长路径支持 打开注册表编辑器:regedit 找到如下路径:HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\FileSyte ...
- maven 设置pom 指定jdk版本
<profile> <id>jdk-1.8</id> <activation> <activeByDefault>true</acti ...
- 22)PHP,数组排序函数
详情见: 手册:函数参考-->变量和类型相关扩展-->数组--->对数组进行排序
- Could not open Hibernate Session for transaction; nested exception is org.hibernate.TransactionExcep linux下mysql修改连接超时wait_timeout修改后就ok了
Linux下mysql修改连接超时wait_timeout 1,首先: show variables like '%timeout%': 显示结果: +------------------------ ...
- 系统学习Javaweb10----BootStrap2
学习内容: 1.BootStrap-轮播图 2.BootStrap-排版对齐方式 3.BootStrap-表单元素 4.BootStrap-分页条
- FaceIDViewer.rar
FaceIDViewer用于查看Office工具栏控件的内置图标编号. 压缩包中包含4个文件,打开任何一个都可以进行查询.其中带有V2字样的文件,已经排除掉了空白图标. Excel版动态图: Word ...
- cesium初探之加载三维模型
项目需要用到二三维地图切换,本来准备研究ArcGIS js for Web 3d,但考虑到版权的问题,决定试着用cesium来做,于是花了2天时间抱着试试看的心态把cesium从环境配置到加载三维模型 ...
- spring-mvc基于xml的配置
配置web.xml <!--配置spring-MVC拦截--> <servlet> <servlet-name>DispatcherServlet</serv ...
- JavaScript--DOM,BOM
前戏 到目前为止,我们已经学过了JavaScript的一些简单的语法.但是这些简单的语法,并没有和浏览器有任何交互. 也就是我们还不能制作一些我们经常看到的网页的一些交互,我们需要继续学习BOM和DO ...