[英]How do you read a text file, line by line, and separate contents of each line in Java?
[英]How to print the contents of stringbuilder in each line in a output text file in java
我正在使用一个很大的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
包含所有hedaer和数据一样,因此从一开始到Stringbuilder
数字达到24时,它将用Stringbuilder
将值分成新行。
我不同意您在StringBuilder中进行转储的方法,但是如果您被限制与String builder一起使用,则可以采用这种方法。 保存每个用逗号分隔的行单元格,并用“ |”分隔下一行。
然后在“ |”上使用String标记器 因此,您拥有单独的行,然后在循环中再次在“,”上使用令牌生成器以获取单元格值。 防爆
StringBuilder sample = new StringBuilder();
sample.append("DDD,FFFFFF,KKKK,LLLL).append("|")
.append("KKK,FFFFF,KKK,LLLL");
现在只需使用StringTokenizer并转储文件中的每一行
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.