javaWeb纯文本导出csv文件,前面的0消失问题

本文介绍了一个在导出CSV文件时遇到的问题:员工号中的前导零在导出后消失,并提供了解决方案。通过在员工号前添加制表符( ),可以确保数字的前导零在CSV文件中得以保留。

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

先上导出代码

String header = "序号,工号,姓名,奖项,奖品名,签字\r\n";
	String comma = ",";

	@RequestMapping("/exportAllLuckyUser")
	public void exportAllLuckyUser(HttpServletResponse response) throws IOException {
		response.setHeader("Content-Disposition", "attachment; filename=LuckyUser.csv");
		
		StringBuilder csv = new StringBuilder(header);
		List<LuckyUser> list = luckyUserDao.find(Query.build());
		int i = 1;
		for (LuckyUser luckyUser : list) {
			csv
			.append(i++)
			.append(comma)
			.append("\t").append(luckyUser.getEmployeeNo())// 前面加\t,即tab符
			.append(comma)
			.append(luckyUser.getUsername())
			.append(comma)
			.append(luckyUser.getLevelName())
			.append(comma)
			.append(luckyUser.getPrizeName())
			.append(comma)
			.append("        ")
			.append("\r\n");
		}
		OutputStreamWriter osw = new OutputStreamWriter(response.getOutputStream(), "GBK");    
		osw.write(csv.toString());    
		osw.flush();   
	}

如代码所示luckyUser.getEmployeeNo()这句返回员工号,员工号前面有数字0,如001234

在导出csv时,打开csv前面的0消失,变成1234.解决办法是在前面加上\t


评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值