题目:给定一个文件和一个字符串,判断文件是否包含该字符串,如果包含,请打印出包含该字符串的行号以及该行的全部内容。
思路: ①使用缓冲流(BufferedReader)读取文件,定义初始行号为0。
②遍历文件每一行并判断,包含则将行号和行内容存入hashMap中,行号作为key,行内容作为value.最后遍历hashMap即可
下面是实现的代码:
package com.sgl.io;
import java.io.BufferedReader;
import java.io.FileReader;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
public class FileFindString {
public static void findStringInFile(String fileName, String subStr)
throws Exception {
BufferedReader br = new BufferedReader(new FileReader(fileName));
Map res = new HashMap<>();
int lineNum = 0; //记录行号
String line;
while ((line = br.readLine()) != null) {
lineNum++;
// 第一种:contains
// if (line.contains(subStr)) {
// res.put(lineNum, line);
//``}
// 第二种:indexOf
if(line.indexOf(subStr)!=-1){
res.put(lineNum, line);
}
}
//遍历hashMap,key为行号,value为字符串
if (res.isEmpty()) {
System.out.println("文件【" + fileName + "】中没有【" + subStr + "】子串");
} else {
Iterator> it = res.entrySet().iterator();
while (it.hasNext()) {
Entry entry = it.next();
System.out.println("第" + entry.getKey() + "行:\t"
+ entry.getValue());
}
}
br.close();
}
public static void main(String[] args) throws Exception {
findStringInFile("test1.txt", "time");
}
}
测试用文件为:
程序运行结果为:
小结:程序不难,需求很明确,主要是对IO流中相关方法要熟悉。其次Map的遍历也是一个重点。