zoukankan      html  css  js  c++  java
  • [置顶] Java编程笔试题之一 ----文件操作

    题目:给定一个文件和一个字符串,判断文件是否包含该字符串,如果包含,请打印出包含该字符串的行号以及该行的全部内容。

    思路: ①使用缓冲流(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<Integer, String> 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<Entry<Integer, String>> it = res.entrySet().iterator();
    			while (it.hasNext()) {
    				Entry<Integer, String> entry = it.next();
    				System.out.println("第" + entry.getKey() + "行:	"
    						+ entry.getValue());
    			}
    		}
    		br.close();
    	}
    
    	public static void main(String[] args) throws Exception {
    		findStringInFile("test1.txt", "time");
    	}
    
    }
    


    测试用文件为:

    程序运行结果为:

    小结:程序不难,需求很明确,主要是对IO流中相关方法要熟悉。其次Map的遍历也是一个重点。

  • 相关阅读:
    MxNet Windows下安装
    Binary Tree Postorder Traversal--leetcode难题讲解系列
    Populating Next Right Pointers in Each Node II--leetcode难题讲解系列
    Recover Binary Search Tree--leetcode难题讲解
    bash + script
    Linux笔记
    谷歌面经 Tree Serialization
    Python strange questions list
    bit操作 转
    ubuntu系统从中文环境改成英文环境
  • 原文地址:https://www.cnblogs.com/suncoolcat/p/3367766.html
Copyright © 2011-2022 走看看