java导出csvutile,Java之利用openCsv导出csv文件

importcom.opencsv.CSVWriter;importcom.opencsv.bean.StatefulBeanToCsv;importcom.opencsv.bean.StatefulBeanToCsvBuilder;importcom.opencsv.exceptions.CsvDataTypeMismatchException;importcom.opencsv.exceptions.CsvRequiredFieldEmptyException;importlombok.extern.slf4j.Slf4j;importorg.springframework.stereotype.Component;importjavax.servlet.http.HttpServletResponse;import java.io.*;importjava.util.List;/*** CSV 工具类

*

*@authorjing*/@Slf4j

@Componentpublic class CSVUtils{/*** 将前台传递的数据生成csv文件

*@paramexportResults

*@paramfileName

*@paramheader

*@throwsIOException

*@throwsCsvDataTypeMismatchException

*@throwsCsvRequiredFieldEmptyException*/

public static void generateCsvFile(List exportResults, String fileName, String[] header) throwsIOException, CsvDataTypeMismatchException, CsvRequiredFieldEmptyException {

Writer writer= newFileWriter(fileName);//写表头

CSVWriter csvWriter = newCSVWriter(writer, CSVWriter.DEFAULT_SEPARATOR, CSVWriter.NO_QUOTE_CHARACTER, CSVWriter.NO_ESCAPE_CHARACTER, CSVWriter.DEFAULT_LINE_END);

csvWriter.writeNext(header);//写内容

StatefulBeanToCsv beanToCsv = newStatefulBeanToCsvBuilder(writer).build();

beanToCsv.write(exportResults);

csvWriter.close();

writer.close();

}/*** 读取csv文件流返回前端下载

*@paramfileName

*@paramresponse

*@throwsUnsupportedEncodingException*/

public static void readCsvFileStream(String fileName, HttpServletResponse response) throwsUnsupportedEncodingException {

String myFileName= new String(fileName.getBytes("utf-8"), "gbk");

File file= newFile(myFileName);if(file.exists()) {

response.setContentType("application/force-download");//设置强制下载不打开

response.addHeader("Content-Disposition", "attachment;fileName=" + myFileName);//设置文件名

byte[] buffer = new byte[1024];

FileInputStream fis= null;

BufferedInputStream bis= null;try{

fis= newFileInputStream(file);

bis= newBufferedInputStream(fis);

OutputStream os=response.getOutputStream();int i =bis.read(buffer);while (i != -1) {

os.write(buffer,0, i);

i=bis.read(buffer);

}

}catch(Exception e) {

e.printStackTrace();

}finally{if (bis != null) {try{

bis.close();

}catch(IOException e) {

e.printStackTrace();

}

}if (fis != null) {try{

fis.close();

}catch(IOException e) {

e.printStackTrace();

}

}

}

}if(file.delete()){

log.error(file.getName()+ " 文件已被删除!");

}else{

log.error("文件删除失败!");

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值