sfit0144 (李四) 2015-01-10 18:00:25
1
Sfit0734 (Sfit0734) 2015-01-10 18:00:38
go home
sfit0144 (李四) 2015-01-10 18:09:52
下班
261340 (叶在宗) 2015-01-10 18:10:05
图片: {5F4C20B4-134F-4014-801D-8FFBA58587E9}.png
sfit0513 (蒋大有) 2015-01-10 18:43:55
下班
sfit0122 (雷一果) 2015-01-10 19:06:16
下班

将上面数据分析成下面格式,上面数据也是存在于文件当中,下面数据也是分析完后最后也放在文件当中

打卡日期    姓名      上班打卡             下班打卡             
2015-01-10  何科                           2015-01-10 19:46:05
2015-01-10  刘俊                           2015-01-10 20:39:00
2015-01-10  匡磊                           2015-01-10 19:43:52
2015-01-10  叶在宗                         2015-01-10 18:10:05
2015-01-10  李四      2015-01-10 18:00:25  2015-01-10 18:09:52
2015-01-10  蒋大有                         2015-01-10 18:43:55
2015-01-10  雷一果                         2015-01-10 19:06:16
2015-01-13  何科      2015-01-13 09:22:58  2015-01-13 19:01:07
2015-01-13  刘俊      2015-01-13 09:26:34  2015-01-13 19:28:37

下面是代码:

public class MessageHistory {

    Map<String, MessageSenderInfo> lines = new HashMap<String, MessageSenderInfo>();
String outputPath;
public static void main(String[] args) {
MessageHistory messageHistory = new MessageHistory();
messageHistory.multiReadMessage();
messageHistory.outputCardRecordsToFile();
} public MessageHistory() {
outputPath = System.getProperty("user.dir")+File.separator+formatDate(new Date()) + "—打卡记录.txt";
File f = new File(outputPath);
if(f.exists()){
f.delete();
}
} /**
* 消息文件以work开头
* 读取文件
*/
public void multiReadMessage(){
File dir = new File(System.getProperty("user.dir"));
if(dir.getParentFile().exists()){
for(File file:dir.listFiles()){
if(file.getName().trim().matches("^work.*\\.txt$")){
System.out.println("start read "+file.getAbsolutePath());
readMessage(file.getAbsolutePath());
}
}
}
} public void lineToMap(String line) {
if (line.matches("^[A-Za-z0-9]{6}.*")) {
int index = line.indexOf("(");
int lastIndex = line.lastIndexOf(")");
if (index > 0 && lastIndex > 0) {
String workCode = line.substring(0, index);
String name = line.substring(index + 1, lastIndex);
String dateStr = line.substring(lastIndex + 1).trim();
Date date = parseDate(dateStr);
String key = formatDate(date) + "--" + workCode;
MessageSenderInfo recoderBean = lines.get(key);
if (recoderBean == null) {
recoderBean = new MessageSenderInfo(workCode, name);
recoderBean.setAtWorkTime(date);
} else {
if (recoderBean.getOffWorkTime() == null) {
recoderBean.setOffWorkTime(date);
}else{
if(date.getTime() < recoderBean.getAtWorkTime().getTime()){
recoderBean.setAtWorkTime(date);
}else if(date.getTime() > recoderBean.getOffWorkTime().getTime()){
recoderBean.setOffWorkTime(date);
}
} }
lines.put(key, recoderBean);
}
}
} public List<Map.Entry<String,MessageSenderInfo>> sortMessage(){
List<Map.Entry<String,MessageSenderInfo>> list = new ArrayList<Map.Entry<String,MessageSenderInfo>>(lines.entrySet());
Collections.sort(list, new MessageComparator());
return list;
}
/**
* 输出到文件
*/
public void outputCardRecordsToFile() {
printHeader();
System.out.println("总记录:"+lines.size());
List<Map.Entry<String,MessageSenderInfo>> list = sortMessage();
for (Map.Entry<String, MessageSenderInfo> e : list) {
MessageSenderInfo messageSenderInfo = e.getValue();
String line = formatDate(messageSenderInfo.getAtWorkTime()) + " "+
formatStringLen(messageSenderInfo.getName(),8) + " " ;
if(messageSenderInfo.getOffWorkTime() == null){
if(getHour(messageSenderInfo.getAtWorkTime()) >= 12){
line += formatStringLen("",21);
}
line+=formatLongDate(messageSenderInfo.getAtWorkTime());
}else
if(messageSenderInfo.getOffWorkTime() != null){
line += formatLongDate(messageSenderInfo.getAtWorkTime()) + " " ;
line+=formatLongDate(messageSenderInfo.getOffWorkTime());
}
writeLine(outputPath, line);
}
}
/**
* 打印头部
*/
public void printHeader(){
String line = formatStringLen("打卡日期",12)+
formatStringLen("姓名",10)+
formatStringLen("上班打卡",21)+
formatStringLen("下班打卡",21);
writeLine(outputPath, line);
} /**
* 格式化字符串长度
* @param s
* @param len
* @return
*/
public String formatStringLen(String s, int len) {
if (len > s.getBytes().length) {
StringBuilder sBuilder = new StringBuilder(s);
for (int i = 0; i < len - s.getBytes().length; i++) {
sBuilder.append(" ");
}
return sBuilder.toString();
}
return s;
} public void writeLine(String path, String s) {
File f = new File(path);
OutputStream os = null;
try {
os = new FileOutputStream(f, true);
Writer wirte = new OutputStreamWriter(os, "UTF-8");
BufferedWriter bufferedWriter = new BufferedWriter(wirte);
bufferedWriter.write(s);
bufferedWriter.newLine();
bufferedWriter.flush();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (os != null) {
try {
os.close();
os = null;
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
} public void readMessage(String path) {
InputStream ins = null;
BufferedReader buf = null;
try {
ins = new FileInputStream(path);
buf = new BufferedReader(new InputStreamReader(ins, codeString(path)));
String line = null;
while ((line = buf.readLine()) != null) {
lineToMap(line.trim());
}
} catch (FileNotFoundException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (ins != null) {
try {
ins.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
} /**
* 排序比较
* @author sfit0734
*
*/
class MessageComparator implements Comparator<Map.Entry<String,MessageSenderInfo>> {
@Override
public int compare(Map.Entry<String,MessageSenderInfo> e1, Map.Entry<String,MessageSenderInfo> e2) {
MessageSenderInfo m1 = e1.getValue();
MessageSenderInfo m2 = e2.getValue();
String dateStr = formatDate(m1.getAtWorkTime());
String dateStr1 = formatDate(m2.getAtWorkTime()); int result = dateStr.compareTo(dateStr1);
if(result != 0){
return result;
}else{
return m1.getName().compareTo(m2.getName());
}
}
}; public Date parseDate(String dataStr) {
DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
//String dateString = formatter.format(currentTime);
Date date = null;
try {
date = formatter.parse(dataStr);
} catch (ParseException e) { e.printStackTrace();
}
return date;
} public String formatDate(Date date) {
DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd");
String dateString = formatter.format(date); return dateString;
} public String formatLongDate(Date date) {
DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String dateString = formatter.format(date); return dateString;
}
/**
* 获取小时
* @param d
* @return
*/
public int getHour(Date d){
Calendar cal=Calendar.getInstance();
cal.setTime(d); return cal.get(Calendar.HOUR_OF_DAY);
} /**
* 判断文件的编码格式
* @param fileName :file
* @return 文件编码格式
* @throws IOException
* @throws Exception
*/
public String codeString(String fileName) throws IOException {
BufferedInputStream bin = new BufferedInputStream(
new FileInputStream(fileName));
int p = (bin.read() << 8) + bin.read();
String code = null; switch (p) {
case 0xefbb:
code = "UTF-8";
break;
case 0xfffe:
code = "Unicode";
break;
case 0xfeff:
code = "UTF-16BE";
break;
default:
code = "GBK";
} return code;
} class MessageSenderInfo {
String workCode;
String name;
Date atWorkTime;
Date offWorkTime; public MessageSenderInfo() {
super();
// TODO Auto-generated constructor stub
} public MessageSenderInfo(String workCode, String name) {
super();
this.workCode = workCode;
this.name = name; } public String getWorkCode() {
return workCode;
} public void setWorkCode(String workCode) {
this.workCode = workCode;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public Date getAtWorkTime() {
return atWorkTime;
} public void setAtWorkTime(Date atWorkTime) {
this.atWorkTime = atWorkTime;
} public Date getOffWorkTime() {
return offWorkTime;
} public void setOffWorkTime(Date offWorkTime) {
this.offWorkTime = offWorkTime;
}
}
}

map数据的分组,list数据排序 数据筛选的更多相关文章

  1. [转]WPF and Silverlight 学习笔记(二十五):使用CollectionView实现对绑定数据的排序、筛选、分组

    在第二十三节,我们使用CollectionView实现了对于绑定数据的导航,除导航功能外,还可以通过CollectionView对数据进行类似于DataView的排序.筛选等功能. 一.数据的排序: ...

  2. 开始VS 2012中LightSwitch系列的第4部分:太多信息了!使用查询来排序和筛选数据

    [原文发表地址]  Beginning LightSwitch in VS 2012 Part 4: Too much information! Sorting and Filtering Data ...

  3. MySQL 对分组后的同类数据进行拼接字符串

    MySQL 对分组后的同类数据进行拼接字符串 写后台方法时遇到个问题,需要将表内同一订单号的操作记录流水进行简单拼接输出,不想取出来再操作,找了个mysql的方法直接操作 //group_concat ...

  4. oracle 根据字段分组取第一条数据及rank函数说明

    当前有这样一个需求,根据外键对子表数据进行分组,取每组中的一条数据就行了,如图: 如:COMMANDID = 26的有两条,只取一条数据. sql语句: select * from(select SY ...

  5. mybatis从数据库中取数据且分组,返回分组数据

    mapper.xml文件 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PU ...

  6. Java将数据进行分组处理

    将传人的数据进行分组,使用map保存每组的数据. /** * 将取出的数据进行分组 * @param list * @return */ public Map<Integer,Object> ...

  7. 用 Python 排序数据的多种方法

    用 Python 排序数据的多种方法 目录 [Python HOWTOs系列]排序 Python 列表有内置就地排序的方法 list.sort(),此外还有一个内置的 sorted() 函数将一个可迭 ...

  8. mysql 查询数据时按照A-Z顺序排序返回结果集

    mysql 查询数据时按照A-Z顺序排序返回结果集 $sql = "SELECT * , ELT( INTERVAL( CONV( HEX( left( name, 1 ) ) , 16, ...

  9. MFC listcontrol 分列 添加行数据 点击列头排序

    适用于 对话框程序 1.在工具箱中拖出 ListControl,然后右键-属性,view-Report 让你的ListControl变成这幅模样! 2.添加ListControl控件的control类 ...

  10. IOS第七天(3:UiTableView 模型和数据的分组的显示)

    *************UiTableView模型和数据的分组的显示 #import "HMViewController.h" #import "HMHero.h&qu ...

随机推荐

  1. intellij idea 使用用到的问题

    1.github error setting certificate verify locations使用github时报错,解决方法: git config --system http.sslcai ...

  2. 连通 OR 不连通(NOJ 1044)

    比赛描述 给定一个无向图,一共n个点,请编写一个程序实现两种操作: D x y 从原图中删除连接x,y节点的边. Q x y 询问x,y节点是否连通 输入 第一行两个数n,m(5<=n<= ...

  3. hdu 5040 Instrusive【BFS+优先队列】

    11733274 2014-09-26 12:42:31 Accepted 5040 62MS 1592K 4848 B G++ czy 先转一个优先队列的用法: http://www.cppblog ...

  4. 标准C程序设计七---17

    Linux应用             编程深入            语言编程 标准C程序设计七---经典C11程序设计    以下内容为阅读:    <标准C程序设计>(第7版) 作者 ...

  5. Fragment的广播消息接收

    这种方式不用在配置文件加东西 广播注册,可以写在Activity(onCreate),也可以写在Fragment(onActivityCreated)里. LocalBroadcastManager ...

  6. 有关WebView开发问题(转)

    http://blog.sina.com.cn/s/blog_8241e8510101btvk.html 如何创建WebView: 1.添加权限:AndroidManifest.xml中必须使用许可& ...

  7. Netty构建游戏服务器(一)--基本概念与原理

    一,Netty是什么 1,Netty是由 JBOSS提供的一个 java开源框架. 2,Netty是JAR包,一般使用ALL-IN-ONE的JAR包就可以开发了. 3,Netty不需要运行在Tomca ...

  8. ssh的安装和使用

    1.ssh的安装 服务器端:sudo apt-get install openssh-serve 客户端:sudo apt-get install openssh-client 2.ssh的操作 查看 ...

  9. 《Java虚拟机原理图解》1.4 class文件中的字段表集合--field字段在class文件中是怎样组织的

    0.前言 了解JVM虚拟机原理是每一个Java程序员修炼的必经之路.但是由于JVM虚拟机中有很多的东西讲述的比较宽泛,在当前接触到的关于JVM虚拟机原理的教程或者博客中,绝大部分都是充斥的文字性的描述 ...

  10. [转] sql 删除表数据的drop、truncate和delete用法

    删除表数据的关键字,大家记得最多的可能就是delete.然而,我们做数据库开发,读取数据库数据.对另外的drop.truncate用得就比较少了. 1 drop 出没场合:drop table  ta ...