题目

1、交易明细文件内容如下例:


客户号 姓名 所述机构号 性别 帐号 发生时间 发生额

000001|刘德华|0000|1|4155990188888888|20060720200005|300.00

000201|晓龙|0002|1|4155990199999999|20060720200005|500.00

000101|黄晓明|0012|1|4155990100000000|20060720200005|1000.50

000101|张东健|0012|1|4155990155555555|20060720200005|600.99

000301|梁朝伟|0013|0|4155990111111111|20060722201005|5000.00

000001|刘德华|0000|1|4155990188888888|20060725200005|200.00


2、一行是一条交易明细,每行分6列,列间用|分隔。#为注释符号。

3、类TransRecord存储一条明细

4、解析文件数据至TransRecord[]

5、实现如下功能:

public class TransRecordManager{

/**

* 记录数组

*/

private TransRecord[] records;

/**
* 加载数据
* @param in - 数据流
* @return
* @throws - 解析过程中IO错误
*/
public void load(InputStream in) throws IOException; /**
* 加载数据
* @param fileName - 包含记录数据的文件名
* @return
* @throws - 解析过程中IO错误
*/
public void load(String fileName) throws IOException; /**
* 取所有记录
* @return 所有记录数组或null
*/
public TransRecord[] getAll(); /**
* 按客户号查询记录
* @param customerNumber - 客户号
* @return 符合条件的记录数组或null
*/
public TransRecord[] findByCustomerNumber(String customerNumber); /**
* 按日期段查询记录
* @param start - 开始日期
* @param end - 结束日期
* @return 符合条件的记录数组或null
*/
public TransRecord[] findByDate(String start, String end); /**
* 取得总金额
* @return 总金额
*/
public BigDecimal totalAmount(); /**
* 按金额排序
* @return 按金额升序排序的结果
*/
public TransRecord[] sortByAmount(); /**
* 打印
* @param out - 输出流
*/
public void print(OutputStream out);

}

提示:排序、查询采用java.util.Arrays和java.util.Collections中的方法

package com.lanqiao.dmeo5;

import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.math.BigDecimal;
import java.util.Scanner; public class TransRecordManager {
private TransRecord[] records; Scanner sc = new Scanner(System.in); public void show() {
System.out.println("=====交易记录管理系统=====");
System.out.println("1.加载数据");
System.out.println("2.");
System.out.println("3.查询记录(1.根据客户号,2.根据日期)");
System.out.println("4.总金额为"); System.out.println("请选择:");
int choice = sc.nextInt();
switch (choice) {
case 1: break;
case 2: break; case 3: break;
case 4: break; default:
break;
}
} /**
* 加载数据
*
* @param in
* - 数据流
* @return
* @throws -
* 解析过程中IO错误
*/
public void load(InputStream in) throws IOException {
String str = null;
String[] strs = null;
try {
TransRecord tR = null;
InputStreamReader input = new InputStreamReader(in);
BufferedReader bfr = new BufferedReader(input);
for (int i = 0; (str = bfr.readLine()) != null; i++) {
if (str.startsWith("#") || str.startsWith(" ")) { str = bfr.readLine();
} else {
strs = str.split("[|]");
//赋值客户编号
tR.setCustomerNumber(strs[0]);
tR.getCustomerNumber(); tR.setCustomerName(strs[1]);
tR.getCustomerName(); tR.setInstitutionNum(strs[2]);
tR.getInstitutionNum(); tR.setSex(Integer.parseInt(strs[3]));
tR.getSex(); tR.setAccountNumber(strs[4]);
tR.getAccountNumber(); tR.setHappenTime(strs[5]);
tR.getHappenTime(); tR.setAmount(new BigDecimal(strs[6]));
tR.getAmount(); records[i] = tR;
System.out.println(tR.toString()); }
}
bfr.close(); } catch (IOException e) {
System.out.println("捕获信息异常");
}
} /**
* 加载数据
*
* @param fileName
* - 包含记录数据的文件名
* @return
* @throws -
* 解析过程中IO错误
*/
public void load(String fileName) throws IOException {
try {
// 创建输入流
FileInputStream fI = new FileInputStream(fileName);
load(fI);
// 关闭流
fI.close();
} catch (IOException e) {
e.printStackTrace();
System.out.print("获取IO流信息异常!");
} } /**
* 取所有记录
*
* @return 所有记录数组或null
*/
public TransRecord[] getAll() {
return records;
} /**
* 按客户号查询记录
*
* @param customerNumber
* - 客户号
* @return 符合条件的记录数组或null
*/
public TransRecord[] findByCustomerNumber(String customerNumber) {
return records; } /**
* 按日期段查询记录
*
* @param start
* - 开始日期
* @param end
* - 结束日期
* @return 符合条件的记录数组或null
*/
public TransRecord[] findByDate(String start, String end) {
return records; } /**
* 取得总金额
*
* @return 总金额
*/
public BigDecimal totalAmount() {
return null; } /**
* 按金额排序
*
* @return 按金额升序排序的结果
*/
public TransRecord[] sortByAmount() {
return records; } /**
* 打印
*
* @param out
* - 输出流
*/
public void print(OutputStream out) { } }
package com.lanqiao.dmeo5;

import java.math.BigDecimal;

public class TransRecord {
private String customerNumber;//客户号
private String customerName;//客户名
private String institutionNum;//所属机构 private int sex;//性别
private static final String[] SEX = {"女","男"}; private String accountNumber;//账号
private String happenTime;//发生时间
private BigDecimal amount;//发生额 //get set方法
public String getCustomerName() {
return customerName;
}
public void setCustomerName(String customerName) {
this.customerName = customerName;
}
public String getCustomerNumber() {
return customerNumber;
}
public void setCustomerNumber(String customerNumber) {
this.customerNumber = customerNumber;
}
public String getInstitutionNum() {
return institutionNum;
}
public void setInstitutionNum(String institutionNum) {
this.institutionNum = institutionNum;
}
public String getAccountNumber() {
return accountNumber;
}
public void setAccountNumber(String accountNumber) {
this.accountNumber = accountNumber;
}
public String getHappenTime() {
return happenTime;
}
public void setHappenTime(String happenTime) {
this.happenTime = happenTime;
} public void setSex(int sex) {
this.sex = sex;
}
public BigDecimal getAmount() {
return amount;
}
public void setAmount(BigDecimal amount) {
this.amount = amount;
}
public static String[] getSex() {
return SEX;
} //重写toString方法
public String toString() {
return "TransRecord [customerName=" + customerName + ", customerNumber=" + customerNumber + ", institutionNum="
+ institutionNum + ", accountNumber=" + accountNumber + ", happenTime=" + happenTime + ", sex=" + sex
+ ", amount=" + amount + "]";
} }
package com.lanqiao.dmeo5;

import java.io.IOException;

public class Test {
public static void main(String[] args) {
TransRecordManager t = new TransRecordManager(); try {
t.load(System.getProperty("usr.dir")+"~/Java/src");
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}

2018.4.6 java交易记录系统的更多相关文章

  1. 20172328 2018—2019《Java软件结构与数据结构》第二周学习总结

    20172328 2018-2019<Java软件结构与数据结构>第二周学习总结 概述 Generalization 本周学习了第三章集合概述--栈和第四章链式结构--栈.主要讨论了集合以 ...

  2. 2018年最新Java面试题及答案整理(持续完善中…)

    2018年最新Java面试题及答案整理(持续完善中…) 基础篇 基本功 面向对象特征 封装,继承,多态和抽象 封装封装给对象提供了隐藏内部特性和行为的能力.对象提供一些能被其他对象访问的方法来改变它内 ...

  3. 2018年,Java程序员转型大数据开发,是不是一个好选择?

    近日网上有一篇关于Java程序员职场生存现状的文章“2017年 Java 程序员,风光背后的危机”,在Java程序员圈子里引起了广泛关注和热议. 2017年,Java 程序员面临更加激烈的竞争. 不得 ...

  4. 2018.8.3 Java中容易犯错误的问题思考与总结

    Java容易犯错误的问题思考 float型 float f = 3.4 是否正确 不正确,应该用强制类型转换.如下所示:float f = (float)3.4 或float f = 3.4f 在ja ...

  5. 2018.2.2 java中的Date如何获取 年月日时分秒

    package com.util; import java.text.DateFormat; import java.util.Calendar; import java.util.Date; pub ...

  6. 2018/1/15 JAVA多线程相关

    本文不说synchronized相关,它就是JAVA的一个保留关键字,jdk自己实现了它,但说真的,可应用场景真的少,相比lock接口,它还是被淘汰好吧; 首先,说说lock接口,lock接口是一个工 ...

  7. 链家2018春招Java工程师编程题题解

    Light 题目描述 在小红家里面,有n组开关,触摸每个开关,可以使得一组灯泡点亮.现在问你,使用这n组开关,最多能够使得多少个灯泡点亮呢? 输入 第一行一个n,表示有n组开关.接下来n行,每行第一个 ...

  8. 爱奇艺2018春招Java工程师编程题题解

    字典序最大子序列 题目描述 对于字符串a和b,如果移除字符串a中的一些字母(可以全部移除,也可以一个都不移除)就能够得到字符串b我们就称b是a的子序列. 例如."heo"是&quo ...

  9. 2018年最新JAVA面试题总结之框架(4)

    转自于:https://zhuanlan.zhihu.com/p/40098726 1.谈谈对spring框架的了解 ,spring有什么作用(IOC,AOP),spring的核心是什么?回答:Spr ...

随机推荐

  1. mysql由浅入深探究(二)----mysql用户操作

    上一节我们完成了mysql的安装,现在我们将开启实战模式,完成一些基本的mysql操作.这节我们分为一些几个内容: mysql中用户新建 mysql中用户删除 mysql中用户修改 mysql中用户查 ...

  2. Fiddler如何抓取HTTPS协议的网页

    Fiddler默认只能抓取HTTP协议的网页,不能抓取HTTPS协议的网页,而我们很多时候,都需要抓HTTPS协议的网页,比如抓淘宝数据等.今天,韦玮老师会为大家讲解如何使用Fiddler抓取HTTP ...

  3. Oracle数据库恢复之resetlogs

    实验环境:RHEL 5.4 + Oracle 11.2.0.3 如果是一名合格的Oracle DBA,对resetlogs这种关键字都应该是极其敏感的,当确认需要这种操作时一定要三思而后行,如果自己不 ...

  4. codeforces 352D - Jeff and Furik【期望dp】

    首先恋人操作过一轮之后逆序对不会变多,所以设f[i]为把i个逆序对消掉的期望次数,f[i]=0.5f[i-2]+0.5f[i]+2,化简然后递推即可 #include<iostream> ...

  5. left join on 和where条件的放置(转)

    http://blog.csdn.net/muxiaoshan/article/details/7617533

  6. mysql5.7日志时间戳(log_timestmaps)与系统时间不一致问题以及日志报Got an error reading communication packets情况分析

    一.mysql安装后error_log日志时间戳默认为UTC(如下图),因此会造成与系统时间不一致,与北京时间相差8个小时. 解决errro_logs时间戳与linux系统时间不一致问题 step1: ...

  7. 12.创建高级联结---SQL

    一.使用表别名 SQL除了可以对列名和计算字段使用别名,还允许给表名起别名.这样做有两个主要理由: 缩短SQL语句: 允许在一条SELECT语句中多次使用相同的表. SELECT cust_name, ...

  8. hdu6070Dirt Ratio 多校题 套路二分

    比赛中我看了一眼题目就觉得是二分的套路,跟miaom说,结果发现miaom开始碎觉 miaom醒来以后表示这是道凸包合并(%%%) 我&wzf2000:那您快写啊 miaom:我不会写啊 莫名 ...

  9. 【手撸一个ORM】第六步、对象表达式解析和Select表达式解析

    说明 一个Orm自然不仅仅包含条件表达式,还会有如下的场景: OrderBy(s => s.StudentName) Select<StudentDto>(s => new S ...

  10. (转)nginx应用总结(1)--基础认识和应用参数优化配置

    在linux系统下使用nginx作为web应用服务,用来提升网站访问速度的经验已五年多了,今天在此对nginx的使用做一简单总结. 一.nginx服务简介Nginx是一个高性能的HTTP和反向代理服务 ...