Java倒序读取文件夹最新更改的文件

本文介绍了一种通过倒序读取方式来快速获取文件中最新写入内容的方法,特别适用于实时监控文件更新的场景。文章详细展示了如何使用Java代码实现文件的倒序读取,包括如何定位到文件末尾,逐行逆向读取直至找到含有特定关键字的行,以及如何处理字符编码转换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

借鉴其他博客上的方法,自己整理了一个倒序读取最新文件的方法,如有侵权则删除。

public Map<String,String> read(String fileName ) {
		// 获取最新改动的文件名
		File path = new File(fileName);
		if (path.exists()) {
			// 列出该目录下所有文件和文件夹
			File[] files = path.listFiles();
			// 按照文件最后修改日期倒序排序
			Arrays.sort(files, new Comparator<File>() {
				@Override
				public int compare(File file1, File file2) {
					return (int) (file2.lastModified() - file1.lastModified());
				}
			});
			fileName += files[0].getName();
		}
		Map<String, String> map = new HashMap<String, String>();
		File file = new File(fileName);
		if (file.exists()) {
			RandomAccessFile rf = null;
			try {
				rf = new RandomAccessFile(fileName, "r");
				long len = rf.length();
				long start = rf.getFilePointer();//返回此文件当前偏移量
				long nextend = len + start - 1;
				rf.seek(nextend); //设置偏移量为文件末尾行
				String line;
				int c = -1;
				while (nextend > start) {
					c = rf.read();
					if (c == '\n' || c == '\r') {		//只有行与行之间才有\r\n,这表示读到每一行上一行的			      		    末尾的\n,而执行完read后,
														//指针指到了这一行的开头字符
						line = rf.readLine();
						if (line != null) {
							if (line.contains("string")) {   //判断获取的line
								line = new String(line.getBytes("ISO-8859-1"), "UTF-8");						
							}
							nextend--;
						}
					}
					nextend--;
					rf.seek(nextend);
					if (nextend == 0) {  //读取到第一行时
						rf.seek(0);   //不需要为下次做准备了,但是因为read()方法指针从0到了1,需重置为0
						line = rf.readLine();
						if (line != null) {
							if (line.contains("Heart") || line.contains("Carcheck")) {
								line = new String(line.getBytes("ISO-8859-1"), "UTF-8");
							}
						}
					}
				}
			} catch (FileNotFoundException e) {
				e.printStackTrace();
			} catch (IOException e) {
				e.printStackTrace();
			} finally {
				try {
					if (rf != null) {
						rf.close();
					}
				} catch (Exception e) {
					e.printStackTrace();
				}
			}
			return map;
		}
		return map;
	}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值