Java实现:提取文件中相同的数据并处理

需求:要求对比Excel中的两列中数据是否有相等的数据,对比完后要对相同的数据进行一些操作。(其实可以用Execl中的公式:=IF(COUNTIF($A$2:AColMaxNum,A1),"无效”,"有效")计算得出,Excel 真的很强大。但是感觉有点不甘心 :),回家后又用写了个java程序进行批处理。

本程序将两列数据分别拷贝成两个txt文件进行处理,最后生成output.txt结果数据。再将数据复制到excel文件中即可完成需求。

package db;

import java.io.*;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class ReadTxtUtils {


    public static void main(String args[]) {
        readAndWriteFile();
    }

    /**
     * 读入TXT文件
     */
    public static void readAndWriteFile() {
        String pathname = "F:\\yangchaoyu\\JDBC\\src\\db\\input.txt"; 
        String pathname2 = "F:\\yangchaoyu\\JDBC\\src\\db\\input2.txt"; 
       List<String> List1=new ArrayList<String>();
       List<String> List2=new ArrayList<String>();
       Map<String,String> map=new HashMap<String,String>();
        try (
        	FileReader reader = new FileReader(pathname);	// 建立一个对象,它把文件内容转成计算机能读懂的语言
            BufferedReader br = new BufferedReader(reader);
        		FileReader reader2 = new FileReader(pathname2);	// 建立一个对象,它把文件内容转成计算机能读懂的语言
                BufferedReader br2 = new BufferedReader(reader2);
        ) {
            String line;
       
            while ((line = br.readLine()) != null) {
               List1.add(line);
            }
       
            while ((line = br2.readLine()) != null) {
               List2.add(line);
            }
            //下面是写入文件
            File writeName = new File("output.txt"); // 相对路径,如果没有则要建立一个新的output.txt文件
            writeName.createNewFile(); // 创建新文件,有同名的文件的话直接覆盖
            try (FileWriter writer = new FileWriter(writeName);
                 BufferedWriter out = new BufferedWriter(writer)
            ) {              
                for(String item:List1) {
                	if(List2.contains(item))
                		 out.write(item+'\t'+"无效"+"\r\n"); // \r\n即为换行                   	
                	else 
                		 out.write(item+'\t'+"有效"+"\r\n"); // \r\n即为换               
                }
                out.flush(); // 把缓存区内容压入文件
            }           
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    /**
     * 写入TXT文件
     */
    public static void writeFile() {
        try {
            File writeName = new File("output.txt"); // 相对路径,如果没有则要建立一个新的output.txt文件
            writeName.createNewFile(); // 创建新文件,有同名的文件的话直接覆盖
            try (FileWriter writer = new FileWriter(writeName);
                 BufferedWriter out = new BufferedWriter(writer)
            ) {
                out.write("88888\r\n"); // \r\n即为换行
                out.flush(); // 把缓存区内容压入文件
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
   
}


运行结果如下图所示:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值