计算log文件的开始结束时间差
1 import java.io.BufferedReader; 2 import java.io.BufferedWriter; 3 import java.io.File; 4 import java.io.FileNotFoundException; 5 import java.io.FileReader; 6 import java.io.FileWriter; 7 import java.io.IOException; 8 import java.io.RandomAccessFile; 9 import java.util.ArrayList; 10 import java.util.regex.Matcher; 11 import java.util.regex.Pattern; 12 13 14 public class TimeCount { 15 16 public static void main(String[] args) throws IOException { 17 // TODO Auto-generated method stub 18 //读取具体文件每一行的内容 19 String content; 20 //Job_Objectのlist 21 ArrayList<Job> JobObjecttList = new ArrayList<Job>(); 22 //需要分析文件所在的文件夹 23 String filePath ="C:\\TimeCount\\in\\"; 24 // String filePath =args[0]; 25 File file = new File(filePath); 26 //判断文件或目录是否存在 27 if(!file.exists()){ 28 System.out.println("「"+filePath + " not exists」"); 29 30 } 31 //获取该文件夹下所有的文件 32 File[] fileArray= file.listFiles(); 33 File fileName = null; 34 35 for(int i =0;i<fileArray.length;i++){ 36 fileName = fileArray[i]; 37 //判断此文件是否存在 38 if(fileName.isDirectory()){ 39 System.out.println("「"+fileName.getName()+" not exists」"); 40 41 }else{ 42 BufferedReader bfr = new BufferedReader(new FileReader(filePath+fileName.getName()));
43 Job j = new TimeCount().new Job(); 44 // Job j = new Job(); 45 //正序读取,并将文件名,开始时间放入对象 46 while((content = bfr.readLine()) != null) { 47 //正则表达式匹配到符合时间格式的那一行 48 if(content.matches(".*\\d{4}\\/\\d{2}(\\/\\d{2}).*")) { 49 //正则表达式匹配到符合时间格式的字符串 50 Pattern pt=Pattern.compile("\\d{4}\\/\\d{2}(\\/\\d{2})"); 51 Matcher mt=pt.matcher(content); 52 while(mt.find()) { 53 int a = mt.start()+11; 54 // System.out.println(content.substring(a,a+12)); 55 56 j.setJobId(fileName.getName()); 57 //截取这一行的时分秒的字符串,并保存到Job对象中 58 j.setJobTimeS(content.substring(a,a+12)); 59 break; 60 } 61 break; 62 } 63 } 64 //倒序读取,并将结束时间放入对象 65 readReverse(j,filePath+fileName.getName(),"SJIS"); 66 JobObjecttList.add(j); 67 bfr.close(); 68 69 // System.out.println(fileName.getName()); 70 } 71 } 72 //写结果文件 73 BufferedWriter bfw = new BufferedWriter(new FileWriter("C:\\TimeCount\\out\\result.txt")); 74 // BufferedWriter bfw = new BufferedWriter(new FileWriter(args[1])); 75 //头部标题 76 String contentResultStr ="JobID JobStartTime JobEndTime TimeDiff"; 77 bfw.write(contentResultStr); 78 bfw.write("\n"); 79 String contentResult =""; 80 int timeDiff = 0; 81 //循环输出Job对象的list中的内容 82 for(Job j:JobObjecttList) { 83 System.out.println(j.getJobId() + " "+j.getJobTimeS()+" "+j.getJobTimeE()); 84 85 timeDiff = timeCount(j.getJobTimeS(),j.getJobTimeE()); 86 contentResult = j.getJobId()+" "+j.getJobTimeS()+" "+j.getJobTimeE()+" "+timeDiff; 87 bfw.write(contentResult); 88 bfw.write("\n"); 89 } 90 bfw.close(); 91 } 92 93 /* 94 * 倒序读取,并将结束时间放入对象 95 * */ 96 public static void readReverse(Job j,String filename, String charset) { 97 RandomAccessFile rf = null; 98 try { 99 String content; 100 rf = new RandomAccessFile(filename, "r"); 101 long fileLength = rf.length(); 102 long start = rf.getFilePointer();// 返回此文件中的当前偏移量 103 long readIndex = start + fileLength -1; 104 String line; 105 rf.seek(readIndex);// 设置偏移量为文件末尾 106 int c = -1; 107 while (readIndex > start) { 108 c = rf.read(); 109 if (c == '\n' || c == '\r') { 110 line = rf.readLine(); 111 if (line != null) { 112 content = new String(line.getBytes("ISO-8859-1"),charset); 113 if(content.matches(".*\\d{4}\\/\\d{2}(\\/\\d{2}).*")) { 114 Pattern pt=Pattern.compile("\\d{4}\\/\\d{2}(\\/\\d{2})"); 115 Matcher mt=pt.matcher(content); 116 while(mt.find()) { 117 int a = mt.start()+11; 118 // System.out.println(content.substring(a,a+12)); 119 j.setJobTimeE(content.substring(a,a+12)); 120 break; 121 } 122 break; 123 } 124 // System.out.println(new String(line.getBytes("ISO-8859-1"),charset)); 125 } else { 126 // System.out.println(line); 127 } 128 readIndex--; 129 } 130 readIndex--; 131 rf.seek(readIndex); 132 // if (readIndex == 0) {// 当文件指针退至文件开始处,输出第一行 133 // System.out.println(rf.readLine()); 134 // } 135 } 136 } catch (FileNotFoundException e) { 137 e.printStackTrace(); 138 } catch (IOException e) { 139 e.printStackTrace(); 140 } finally { 141 try { 142 if (rf != null) 143 rf.close(); 144 } catch (IOException e) { 145 e.printStackTrace(); 146 } 147 } 148 } 149 150 /* 151 * 计算每个job的开始结束时间差 152 * */ 153 public static int timeCount(String timeStr,String timeEnd) { 154 int timeStr_Hours = Integer.parseInt(timeStr.substring(0, 2)); 155 int timeEnd_Hours = Integer.parseInt(timeEnd.substring(0, 2)); 156 int timeStr_mins = Integer.parseInt(timeStr.substring(3, 5)); 157 int timeEnd_mins = Integer.parseInt(timeEnd.substring(3, 5)); 158 int timeStr_seconds = Integer.parseInt(timeStr.substring(6, 8)); 159 int timeEnd_seconds = Integer.parseInt(timeEnd.substring(6, 8)); 160 int result = (timeEnd_Hours-timeStr_Hours)*3600 161 +(timeEnd_mins-timeStr_mins)*60 162 +(timeEnd_seconds-timeStr_seconds); 163 return result; 164 } 165 166 /** 167 * Job对象 168 * */ 169 class Job{ 170 private String jobId; 171 private String jobTimeS; 172 private String jobTimeE; 173 public String getJobId() { 174 return jobId; 175 } 176 public void setJobId(String jobId) { 177 this.jobId = jobId; 178 } 179 public String getJobTimeS() { 180 return jobTimeS; 181 } 182 public void setJobTimeS(String jobTimeS) { 183 this.jobTimeS = jobTimeS; 184 } 185 public String getJobTimeE() { 186 return jobTimeE; 187 } 188 public void setJobTimeE(String jobTimeE) { 189 this.jobTimeE = jobTimeE; 190 } 191 } 192 193 }