如何在java中的输出文本文件中的每一行中打印stringbuilder的内容

时间:2018-02-15 15:34:35

标签: java excel string stringbuilder

我正在使用一个很大的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的新行。

1 个答案:

答案 0 :(得分:0)

我不同意你在StringBuilder中转储的方法,但是如果你被限制使用String builder那么你可以遵循这种方法。保存每个用逗号分隔的行单元格和用&#34; |&#34;。

分隔的下一行

然后在&#34; |&#34;上使用String tokenizer。所以你有你自己的行,然后在循环中使用标记器再次在&#34;,&#34;获取单元格值。 前

documentDirectory

现在只需使用StringTokenizer并转储文件中的每一行