package com.winhc.task.util;
import com.alibaba.fastjson.JSON;
import com.aliyun.openservices.shade.org.apache.commons.lang3.StringUtils;
import com.winhc.task.bean.Company;
import com.winhc.task.bean.Student;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.jumpmind.symmetric.csv.CsvReader;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.*;
import java.nio.charset.Charset;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.List;
/**
* -----------------------maven 依赖----------------------------
* CSV解析依赖包
*
* APACHE POI包
*
* -----------------------------------------------------------
*
* @description
*/
public class CsvToXlsxUtil {
private static final Logger log = LoggerFactory.getLogger(CsvToXlsxUtil.class);
//CSV常用分隔符,如需动态扩展设置成配置项
private static final char[] DELIMITERS = {
',',
';',
'\001',
' ',
'\t',
'|',
'#',
'&'
};
public static void main(String[] args) {
String csvFile = "D:\\data\\山西省太原市小店区.csv";
System.out.println(csvToXLSX(csvFile));
}
/**
* 读取CSV文件并写入到XLSX文件中,默认编码
*
* @param csvFileAddress
* @return
*/
public static String csvToXLSX(String csvFileAddress) {
return csvToXLSX(csvFileAddress, "GBK");
}
/**
* 读取CSV文件并写入到XLSX文件中,指定CSV文件编码
*
* @param csvFileAddress
* @param charset
* @return
*/
public static String csvToXLSX(String csvFileAddress, String charset) {
String xlsxFileAddress = "";
FileOutputStream fileOutputStream = null;
try {
//char delimiter = getDelimiter(csvFileAddress);
//xlsxFileAddress = csvFileAddress.replace("csv","xlsx"); //xlsx file address
xlsxFileAddress = csvFileAddress.split("\\.")[0] + ".xls";
XSSFWorkbook workBook = new XSSFWorkbook();
XSSFSheet sheet = workBook.createSheet(getSheetName(csvFileAddress));
int RowNum = -1;
CsvReader csvReader = new CsvReader(csvFileAddress, ',', Charset.forName(charset));
while (csvReader.readRecord()) {
RowNum++;
System.out.println(RowNum);
XSSFRow currentRow = sheet.createRow(RowNum);
for (int i = 0; i < csvReader.getColumnCount(); i++) {
currentRow.createCell(i).setCellValue(csvReader.get(i));
}
}
fileOutputStream = new FileOutputStream(xlsxFileAddress);
workBook.write(fileOutputStream);
return getFileName(xlsxFileAddress);
} catch (Exception e) {
log.error("CsvToXlsxUtil exception :", e);
} finally {
try {
fileOutputStream.close();
} catch (IOException e) {
log.error("CsvToXlsxUtil close FileOutputStream exception :", e);
}
}
return getFileName(xlsxFileAddress);
}
public static void csvToXLSxPlus(String csvFilePath, String xlsxFilePath, String sheetName) {
EasyExcelUtil easyExcelUtil = new EasyExcelUtil();
//easyExcelUtil.init(xlsxFilePath, sheet, head);
easyExcelUtil.init(xlsxFilePath, sheetName);
try {
int RowNum = -1;
CsvReader csvReader = new CsvReader(csvFilePath, ',', StandardCharsets.UTF_8);
csvReader.setSafetySwitch(false);
csvReader.setUseTextQualifier(false);
while (csvReader.readRecord()) {
RowNum++;
System.out.println(RowNum);
List> sumDataList = new ArrayList<>(1);
List
> heads) {
EasyExcelUtil easyExcelUtil = new EasyExcelUtil();
easyExcelUtil.init(xlsxFilePath, sheetName, heads);
easyExcelUtil.init(xlsxFilePath, sheetName);
int RowNum = -1;
try {
File file = new File(csvFilePath);
InputStreamReader r = new InputStreamReader(new FileInputStream(file));
BufferedReader reader = new BufferedReader(r);
String content;
do {
RowNum++;
System.out.println(RowNum);
content = reader.readLine();
if (StringUtils.isBlank(content)) {
break;
}
List