如何在将值加载到csv文件

时间:2015-07-06 07:05:13

标签: java csv regional-settings list-separator

我的要求是将DB中的值写入.csv文件并通过电子邮件发送。用下面的代码从DB中获取值并通过createFile(testFile)方法创建文件并存储在服务器位置然后通过电子邮件发送相同的文件。

//示例输入数据:
SRT678,Textile STS Secure Limited,OMD,First,Last

问题是SRT678转到第1栏,纺织STS安全有限公司 - 第2栏,OMD - 第3栏,但我需要“ Textile STS Secure Limited,OMD ”到第2列。我没有将任何分隔符设置为“,”但我相信默认情况下“,”被视为分隔符。

Excel使用系统区域设置 - 列表分隔符来确定要使用的默认分隔符。有没有办法通过代码进行更改?我如何跳过“,” Textile STS Secure Limited,OMD 并将其列入excel中的相同列。

      public Object extractData(ResultSet rs) {
      List list1 = new ArrayList();
      TestFileInfo testFile = new TestFileInfo();
      String base_name="UsersInfo";
      String file_name=base_name + ".csv";
      testFile.setFileName(file_name);
        String header_row="empid,empName,firstName,lastName\r\n";
      list1.add(header_row);
        boolean valid = true;
        int total = 0;
        while (rs.next()) {
           if (valid) {
               total ++;
               String row = rs.getString("empid") 
                + "," + rs.getString("empName") 
                + "," + rs.getString("firstName")
                + "," + rs.getString("lastName")  
                + "\r\n" ;
            list1.add(row);
           }
           else {
                break;
               }
            }
          if (valid)
        {
            testFile.setTotalRecords(total);
            testFile.setRowList(list1);
        }
        else  
        {
            testFile = null;
        }
      return testFile;
     }

// createFile(testFile);

      static public void createFile( TestFileInfo testFile){
      List rowList = file.getRowList();
      File testFile = new File(location,file.getFileName()); 
     if (!testFile.exists()) {
          testFile.createNewFile();
    }
      FileWriter fstream = new FileWriter(testFile);
        BufferedWriter out = new BufferedWriter (fstream);
        for (Iterator row = rowList.iterator(); row.hasNext();) {
               out.write((String) row.next());
            }
            out.close();
            file.setCsvFile(testFile);
        return ;
       }

感谢您的任何帮助! 谢谢!

1 个答案:

答案 0 :(得分:1)

您的文件是以逗号分隔的。因此,只要它看到逗号,就会将其视为新的列条目。

  

为了省略这一点,我们在双引号中添加条目(" a,b,c")。

此处a,b,c现在位于单列中。

为实现此目的,我们使用.contains()方法并检查其中是否包含逗号。

String x = rs.getString("emid");
if(x.contains("\""))
  x = x.replace("\"", "\"\""); 
if(x.contains(",")) 
   x = "\"" + x + "\"";