需求:要求对比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();
}
}
}
运行结果如下图所示: