Java实现CSV文件输出

在很多时候我们都需要将一些数据集合以某种文件格式输出,其中CSV文件输出是一种比较常用的方式.
下面是一个简单的实现CSV文件输出的代码,与大家共享.

public static boolean createCsv(HttpServletResponse Response, QueryData qryData, String[][] columnName) throws Exception
 {
  String data = "";
  SimpleDateFormat dataFormat = new SimpleDateFormat("yyyyMMddHHmm");
  Date today = new Date();
  String dateToday = dataFormat.format(today);
  if (qryData.size() == 0 || columnName.length == 0)
   return false;

  data += "编号,";
  for (int i = 0; i < columnName.length; i++)
  {
   data += columnName[i][1] + ",";
  }
  data += "/n";
  for (int i = 0; i < qryData.size(); i++)
  {
   data += String.valueOf(i + 1) + ",";
   for (int j = 0; j < columnName.length; j++)
   {
    data += qryData.getRow(i).get(columnName[j][0]) + ",";
   }
   data += "/n";
  }
  StringBuilder str = new StringBuilder();
  str.append(data);
  Response.setHeader("Content-Disposition", "attachment; filename=/"" + dateToday + ".csv" + "/"");
  Response.setCharacterEncoding("shift-jis");
  Response.setContentType("text/plain;charset=shift-jis");
  PrintWriter out = Response.getWriter();
  out.write(str.toString());
  out.flush();
  out.close();
  return true;
 }

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CSV文件validator的实现一般包含以下几个步骤: 1. 读取CSV文件 2. 检查文件格式是否正确 3. 检查文件内容是否符合要求 4. 输出检查结果 以下是一个简单的Java实现示例: ```java import java.io.BufferedReader; import java.io.FileReader; import java.io.IOException; import java.util.ArrayList; import java.util.List; public class CSVValidator { private static final String DELIMITER = ","; public static void main(String[] args) { String filename = "example.csv"; List<String[]> rows = readCSV(filename); boolean isFormatValid = validateFormat(rows); boolean isContentValid = validateContent(rows); if (isFormatValid && isContentValid) { System.out.println("The CSV file is valid!"); } } private static List<String[]> readCSV(String filename) { List<String[]> rows = new ArrayList<>(); try (BufferedReader reader = new BufferedReader(new FileReader(filename))) { String line; while ((line = reader.readLine()) != null) { String[] row = line.split(DELIMITER); rows.add(row); } } catch (IOException e) { e.printStackTrace(); } return rows; } private static boolean validateFormat(List<String[]> rows) { int numColumns = rows.get(0).length; for (String[] row : rows) { if (row.length != numColumns) { System.out.println("The CSV file has inconsistent number of columns!"); return false; } } return true; } private static boolean validateContent(List<String[]> rows) { // TODO: implement content validation logic return true; } } ``` 在这个示例中,我们首先读取CSV文件并将其存储为一个二维字符串数组。然后,我们检查文件格式是否正确,即每一行是否具有相同的列数。最后,我们可以添加适当的逻辑来检查文件内容是否符合要求。如果文件格式和内容都有效,则打印出“CSV文件有效”的消息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值