注意要点:
1、csv中会对数字超过12位时会变为科学计数,超过15位时其他位变为0.解决办法: 在数字后面加上 "\t"
2、图片转换为base64时,sun.misc.BASE64Encoder 方法 Base64一行不能超过76字符,超过会自动换行。在windows系统表现为\r\n ,linnux表现为: \n。
java.util.Base64 方法的加码不会生成换行符。建议推荐使用这个。
csv工具类:
package com.hikvision.modules.util;
/**
* @Description csv导出类
* @Author cx
* @Date 2022/2/16 11:49
* @since
*/
public interface CsvExportable {
/**
*
* @methodName : outputTitleLine
* @description : 输出标题行字符串
* @return : 标题行字符串
*
*/
public String outputCsvTitleLine();
/**
*
* @methodName : outputDataLine
* @description : 输出数据行
* @return : 符合CSV格式的数据行字符串
*
*/
public String outputCsvDataLine();
/**
*
* @methodName : CSVFormat
* @description : 将输入字符串格式化成CSV格式的字符串
* @param input : 输入字符串
* @return : 符合CSV格式的字符串
*
*/
public static String CSVFormat(String input) {
boolean bFound = false;
//如果值中含有逗号、换行符、制表符(Tab)、单引号,双引号,则需要用双引号括起来;
//如果值中包含双引号,则需要用两个双引号来替换。
//正则匹配:",'\"\r\n\t"
bFound = input.matches("(.*)(,|'|\"|\r|\n|\t)(.*)");
if (bFound) {
//如果存在匹配字符
//先将双引号替换为两个双引号
String sTemp = input.replaceAll("\"", "\"\"");
//然后,两端使用"字符
sTemp