我正在使用一个很大的excel文件,我必须使用apache事件库解析它。所以现在我能以某种方式获取每个单元格的值和每个单元格的内容,我将它们存储在一个Struingbuilder
。所以现在我的目标是以这样的方式生成文本文件,以便每个行和列看起来像源excel文件。我正在给出excel文件结构的图片。
XXXXXX XXXXXXXXXXXX XXXXXXXX XXXXXXXXXXX XXXXXXXXX
1 DDD FFFFFF KKKK LLLL
2 KKK FFFFF KKK LLLL
.............................
9 KKK HHH LL JJJ
所以我将文件内容改为
public void endElement(String uri, String localName, String name)
throws SAXException {
StringBuilder row = new StringBuilder();
// Process the last contents as required.
// Do now, as characters() may be called more than once
if(nextIsString) {
int idx = Integer.parseInt(lastContents);
lastContents = new XSSFRichTextString(sst.getEntryAt(idx)).toString();
nextIsString = false;
}
// v => contents of a cell
// Output after we've seen the string contents
if(name.equals("v")) {
//System.out.println(lastContents);
if(!lastContents.isEmpty() )
row.append(lastContents);
/*if(lastContents == null) {
row.append("");
}else {
row.append(SEPARATOR);
}*/
aMethodToParseRow(row);
try {
FileUtils.write(new File("D:\\BM_Amortization_.txt"), formatListToString(pickUpExcelValues));
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
private void aMethodToParseRow(StringBuilder row) {
StringBuilder sb = new StringBuilder();
StringBuilder sb1 = new StringBuilder();int count =0;
if(!(row.toString().equals("Loan details") || row.toString().equals("Fixed") || row.toString().equals("3m")|| row.toString().equals("ACT/364")||row.toString().equals("Amounts * EUR 1")||row.toString().equals("Floating") ||row.toString().equals("ACT/365")||row.toString().equals("43100")||row.toString().toString().equals("6m")||row.toString().toString().equals("ACT/ACT")||row.toString().equals("General information")||row.toString().equals("FA - Reporting")||row.toString().equals("Solvency II Reporting")||row.toString().equals("1y")||row.toString().equals("30/360") )) {
count++;
if(count>0 && count<24)
sb.append(row.toString());
System.out.println(sb.toString());
}
count=0;
}
因此该文件包含24列,因此我可以使用一个代码,在Stringbuilder
中找到24个索引后,将每个单元格内容放入新行吗?
就像Stringbuilder
包含所有的hedaers和数据一样,从Stringbuilder
开始到达24号时开始,它会将值分成带有separtor的新行。
答案 0 :(得分:0)
我不同意你在StringBuilder中转储的方法,但是如果你被限制使用String builder那么你可以遵循这种方法。保存每个用逗号分隔的行单元格和用&#34; |&#34;。
分隔的下一行然后在&#34; |&#34;上使用String tokenizer。所以你有你自己的行,然后在循环中使用标记器再次在&#34;,&#34;获取单元格值。 前
documentDirectory
现在只需使用StringTokenizer并转储文件中的每一行