我试图在Java中进行文件比较。 如何搜索字符串中的下发生的历史行(忽略空格)Java - 文件比较;在下一个并行行中搜索字符串(忽略空白)
如:
与我的逻辑**File1** **File2** <name>abc</name> | <name>abc</name> Equal <age>21</age> | Not Equal <company>zyz</company> | <age>21</age> Not Equal | <company>zyz</company> Not Equal
目前,我已经与CSV
字符串<name>abc</name>, <age>21</age>, <company>zyz</company>, ####Start of target File####, <name>abc</name>, , <age>21</age>, <company>zyz</company>
问题: 在CSV的第二行中,年龄值为空白。当我的程序检查File1中的第二行和File2中的第二行时,它们不相等,因此它也会给相应的行赋予错误。
需要做什么:我必须忽略空格并检查下一个出现的值,如果两者相等,则将file1的第二行向下移动。
输出必须是这样的
**File1** **File2** <name>abc</name> | <name>abc</name> | <age>21</age> | <age>21</age> <company>zyz</company> | <company>zyz</company>
这里是我到目前为止已经试过
public List<String> FileCompare(String source, String target) {
try {
//String source="D:/reference.xml";
//String target="D:/comparison.xml";
//Diff d=new Diff(myControlXML, myTestXML);
FileReader fr = new FileReader(source);
FileReader fr1 = new FileReader(target);
BufferedReader br = new BufferedReader(fr);
BufferedReader br2 = new BufferedReader(fr1);
String s1,s2;
String st= new String();
String st2= new String();
while((s1 = br.readLine()) != null) {
myList.add(s1);
st=st.concat(s1);
//System.out.println(s1);
}
Collections.addAll(myList, "#########Start of target#########");
while((s2 = br2.readLine())!=null){
st2=st2.concat(s2);
myList1.add(s2);
}
myList.addAll(myList1);
System.out.println(myList);
//System.out.println(myList1);
}
catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return myList;
}
这里是主代码
Compare c=new Compare();
//FileCompare returns CSV string
List<String> s=c.FileCompare("D:/reference.xml", "D:/comparison.xml");
String pdf=s.toString();
String[] tokens=pdf.split(",");
for(String token:tokens)
System.out.println(token);
如何我是否会这样做忽略空白?请帮忙
很多谢谢!
你如何将其转换为CSV?你有没有考虑过像SAX和DOM这样的解析器?你想通过比较来实现什么? –
@DuniyaHilaDalunga - 这里是更新后的帖子,我如何将它转换为CSV – shockwave