欢迎使用优快云-markdown编辑器

本文介绍了一种通过CSV格式优化WEB批量导出Excel的方法,解决了导出速度慢的问题。文中提供了具体的代码实现,并分享了处理中文乱码的经验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

WEB批量导出EXCEL太慢

excel批量导出太慢,可以使用[csv][6]的方式导出:


代码块

设置响应头,例如:

response.reset(); //清空输出流
            response.setCharacterEncoding("UTF-8");
            response.setHeader("Content-disposition","attachment; filename=加息记录列表"+currentTime+".csv"); // 设定输出文件头
            response.setContentType("application/csv"); // 定义输出类型

代码块

工具类,例如:
“` JAVA
public class CsvWriter extends BufferedWriter {

/** 
 * set wirter 
 *  
 * @param out writer 
 */  
public CsvWriter(final Writer out) {  
    super(out);  
}  

/** 
 * csv Write line 
 *  
 * @param csvLine 
 *            csv line 
 * @throws IOException IOException 
 */  
public void writeLine(final List<String> csvLine) throws IOException {  
    StringBuffer sb = new StringBuffer();  

    for (int i = 0; i < csvLine.size(); i++) {  
        String line = csvLine.get(i);  
        if (line == null) {  
            line = "";  
        }  
        sb.append("\"").append(line.replaceAll("\"", "\"\"")).append("\",");  
    }  

    super.write(sb.deleteCharAt(sb.length() - 1).toString());  
    super.newLine();  
}  

}

经验:1,如果中文返回出现??字符,这表明没有加response.setCharacterEncoding(“UTF-8”);这句话。
2,如果返回的中文是“宸茶繃鏈”这种乱码,说明浏览器的解析问题,应该检查下是否忘加response.setHeader(“Content-type”, “text/html;charset=UTF-8”);这句话。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值