繁体   English   中英

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

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM