1087 lines
45 KiB
Java
1087 lines
45 KiB
Java
package com.dbnt.faisp.util;
|
|
|
|
|
|
import java.io.IOException;
|
|
|
|
import java.io.PrintWriter;
|
|
import java.text.DecimalFormat;
|
|
import java.time.format.DateTimeFormatter;
|
|
import java.util.*;
|
|
|
|
|
|
import javax.servlet.http.HttpServletRequest;
|
|
import javax.servlet.http.HttpServletResponse;
|
|
|
|
|
|
import com.dbnt.faisp.main.codeMgt.model.CodeMgt;
|
|
import org.apache.poi.ss.usermodel.BorderStyle;
|
|
import org.apache.poi.ss.usermodel.Cell;
|
|
import org.apache.poi.ss.usermodel.CellStyle;
|
|
import org.apache.poi.ss.usermodel.FillPatternType;
|
|
import org.apache.poi.ss.usermodel.HorizontalAlignment;
|
|
import org.apache.poi.ss.usermodel.IndexedColors;
|
|
import org.apache.poi.ss.usermodel.Row;
|
|
import org.apache.poi.ss.usermodel.Sheet;
|
|
import org.apache.poi.ss.util.CellRangeAddress;
|
|
import org.apache.poi.xssf.usermodel.XSSFDataFormat;
|
|
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
|
|
|
|
import com.dbnt.faisp.main.equip.model.CellPhone;
|
|
import com.dbnt.faisp.main.equip.model.UseList;
|
|
import com.dbnt.faisp.main.fipTarget.model.PartInfo;
|
|
import com.dbnt.faisp.main.fipTarget.model.PartWork;
|
|
import com.dbnt.faisp.main.userInfo.model.UserInfo;
|
|
|
|
import org.springframework.beans.BeanUtils;
|
|
import org.springframework.beans.BeanWrapper;
|
|
import org.springframework.beans.BeanWrapperImpl;
|
|
|
|
|
|
public class Utils {
|
|
|
|
|
|
public static boolean isEmpty(final Object obj) {
|
|
return !isNotEmpty(obj);
|
|
}
|
|
|
|
public static boolean isNotEmpty(final Object obj) {
|
|
if(null == obj) return false;
|
|
else {
|
|
if(obj instanceof String) return "".equals(obj) ? false : true;
|
|
else if(obj instanceof List) return !((List<?>)obj).isEmpty();
|
|
else if(obj instanceof Map) return !((Map<?,?>)obj).isEmpty();
|
|
// else if(obj instanceof Object[]) return 0 == Array.getLength(obj) ? false : true;
|
|
else if(obj instanceof Integer) return !(null == obj);
|
|
else if(obj instanceof Long) return !(null == obj);
|
|
else return false;
|
|
}
|
|
}
|
|
|
|
public static String getTimeStampString(final String format) {
|
|
return getTimeStampString(new Date(), format);
|
|
}
|
|
|
|
public static String getTimeStampString(final Date date) {
|
|
return getTimeStampString(date, "yyyyMMddHHmmss");
|
|
}
|
|
|
|
public static String getTimeStampString(final Date date, final String format){
|
|
java.text.SimpleDateFormat formatter = new java.text.SimpleDateFormat (format, java.util.Locale.KOREA);
|
|
return formatter.format(date);
|
|
}
|
|
|
|
public static String getTimeStampString(String date, final String format) {
|
|
try {
|
|
if(null == date || "".equals(date)) return "";
|
|
|
|
Date d = null;
|
|
date= date.replaceAll("-", "");
|
|
|
|
switch(date.length()) {
|
|
case 14: break;
|
|
case 12: date += "00"; break;
|
|
case 10: date += "0000"; break;
|
|
case 8: date += "000000"; break;
|
|
case 6: date += "01000000"; break;
|
|
case 4: date += "0101000000"; break;
|
|
default: return "";
|
|
}
|
|
|
|
java.text.SimpleDateFormat tmpFormat = new java.text.SimpleDateFormat("yyyyMMddHHmmss", java.util.Locale.KOREA);
|
|
|
|
if("".equals(date)) d = new Date();
|
|
else {
|
|
tmpFormat.setLenient(true);
|
|
d = tmpFormat.parse(date);
|
|
}
|
|
|
|
return getTimeStampString(d, format);
|
|
} catch(Exception e) {
|
|
e.printStackTrace();
|
|
return "";
|
|
}
|
|
}
|
|
|
|
public static String getFileExtention(final String filename) {
|
|
if(null == filename || "".equals(filename)) return "";
|
|
|
|
return -1 < filename.lastIndexOf(".") ? filename.substring(filename.lastIndexOf(".") + 1).toLowerCase() : "";
|
|
}
|
|
|
|
public static String generationSaveName() {
|
|
try {
|
|
Thread.sleep(100);
|
|
} catch (InterruptedException e) {
|
|
e.printStackTrace();
|
|
}
|
|
return Utils.getTimeStampString("yyyyMMdd_HHmmss_SSS");
|
|
}
|
|
|
|
public static void listToExcel(List<ParamMap> list, HttpServletResponse response, String[] headers, String[] headerNames, String[] columnType, String sheetName, String excelFileName) throws IOException {
|
|
if(Utils.isNotEmpty(list)) {
|
|
// 메모리에 100개의 행을 유지합니다. 행의 수가 넘으면 디스크에 적습니다.
|
|
XSSFWorkbook wb = new XSSFWorkbook();
|
|
Sheet sheet = wb.createSheet(sheetName);
|
|
Row headerRow = sheet.createRow(0);
|
|
CellStyle cellStyle1 = wb.createCellStyle(); //쉼표들어간 숫자 양식
|
|
CellStyle cellStyle2 = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle = wb.createCellStyle(); //숫자양식
|
|
|
|
XSSFDataFormat format = wb.createDataFormat();
|
|
cellStyle1.setDataFormat(format.getFormat("#,##0"));
|
|
cellStyle2.setDataFormat(format.getFormat("#"));
|
|
headerStyle.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle.setFillForegroundColor((short)3);
|
|
headerStyle.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
|
|
for(int i=0; i<list.size(); i++) {
|
|
ParamMap rowData = list.get(i);
|
|
Row row = sheet.createRow(i+1);
|
|
|
|
for(int j=0; j<headers.length; j++) {
|
|
Cell cell = row.createCell(j);
|
|
|
|
if(columnType[j].equalsIgnoreCase("Money")) {
|
|
cell.setCellValue(rowData.getInt(headers[j]));
|
|
cell.setCellStyle(cellStyle1);
|
|
} else if(columnType[j].equalsIgnoreCase("Int")) {
|
|
cell.setCellValue(rowData.getInt(headers[j]));
|
|
cell.setCellStyle(cellStyle2);
|
|
} else if(columnType[j].equalsIgnoreCase("String")) {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
} else {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
}
|
|
}
|
|
}
|
|
|
|
for(int j=0; j<headerNames.length; j++) {
|
|
Cell cell = headerRow.createCell(j);
|
|
cell.setCellValue(headerNames[j]);
|
|
cell.setCellStyle(headerStyle);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) + 1000);
|
|
}
|
|
//엑셀이름 한글깨짐방지
|
|
String outputFileName = new String(excelFileName.getBytes("KSC5601"), "8859_1");
|
|
|
|
response.setHeader("Set-Cookie", "fileDownload=true; path=/");
|
|
response.setHeader("Content-Disposition", String.format("attachment; filename=\""+outputFileName+"_"+Utils.getTimeStampString("yyyyMMdd_HHmm")+".xlsx\""));
|
|
|
|
wb.write(response.getOutputStream());
|
|
wb.close();
|
|
} else {
|
|
createNoDataAlert(response);
|
|
}
|
|
|
|
}
|
|
|
|
public static void downExcel(List<ParamMap> list, HttpServletResponse response, String[] headers, String[] headerNames,String[] headerNames2, String[] columnType, String sheetName, String excelFileName) throws IOException {
|
|
if(Utils.isNotEmpty(list)) {
|
|
// 메모리에 100개의 행을 유지합니다. 행의 수가 넘으면 디스크에 적습니다.
|
|
XSSFWorkbook wb = new XSSFWorkbook();
|
|
Sheet sheet = wb.createSheet(sheetName);
|
|
Row headerRow = sheet.createRow(0);
|
|
Row headerRow2 = sheet.createRow(1);
|
|
CellStyle cellStyle1 = wb.createCellStyle(); //쉼표들어간 숫자 양식
|
|
CellStyle cellStyle2 = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle2 = wb.createCellStyle();
|
|
|
|
XSSFDataFormat format = wb.createDataFormat();
|
|
cellStyle1.setDataFormat(format.getFormat("#,##0"));
|
|
cellStyle2.setDataFormat(format.getFormat("#,##0"));
|
|
cellStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle.setFillForegroundColor((short)3);
|
|
headerStyle.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
|
|
//로우그리기
|
|
for(int i=0; i<list.size(); i++) {
|
|
ParamMap rowData = list.get(i);
|
|
Row row = sheet.createRow(i+2);
|
|
|
|
for(int j=0; j<headers.length; j++) {
|
|
Cell cell = row.createCell(j);
|
|
|
|
|
|
if(columnType[j].equalsIgnoreCase("Int")) {
|
|
cell.setCellValue(rowData.getInt(headers[j]));
|
|
cell.setCellStyle(cellStyle2);
|
|
} else if(columnType[j].equalsIgnoreCase("String")) {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
} else {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
}
|
|
}
|
|
}
|
|
|
|
//헤더
|
|
for(int j=0; j<headerNames.length; j++) {
|
|
Cell cell = headerRow.createCell(j);
|
|
cell.setCellValue(headerNames[j]);
|
|
cell.setCellStyle(headerStyle);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) + 1000);
|
|
}
|
|
sheet.addMergedRegion(new CellRangeAddress(0,0,0,1));
|
|
for(int j=0; j<headerNames2.length; j++) {
|
|
Cell cell = headerRow2.createCell(j);
|
|
cell.setCellValue(headerNames2[j]);
|
|
cell.setCellStyle(headerStyle2);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) + 1000);
|
|
}
|
|
//엑셀이름 한글깨짐방지
|
|
String outputFileName = new String(excelFileName.getBytes("KSC5601"), "8859_1");
|
|
|
|
response.setHeader("Set-Cookie", "fileDownload=true; path=/");
|
|
response.setHeader("Content-Disposition", String.format("attachment; filename=\""+outputFileName+"_"+Utils.getTimeStampString("yyyyMMdd_HHmm")+".xlsx\""));
|
|
|
|
wb.write(response.getOutputStream());
|
|
wb.close();
|
|
} else {
|
|
createNoDataAlert(response);
|
|
}
|
|
|
|
}
|
|
|
|
public static void downEquipStatusExcel(List<ParamMap> list, HttpServletResponse response, String[] headers, String[] headerNames,String[] headerNames2, String[] columnType, String sheetName, String excelFileName) throws IOException {
|
|
if(Utils.isNotEmpty(list)) {
|
|
// 메모리에 100개의 행을 유지합니다. 행의 수가 넘으면 디스크에 적습니다.
|
|
XSSFWorkbook wb = new XSSFWorkbook();
|
|
Sheet sheet = wb.createSheet(sheetName);
|
|
Row headerRow = sheet.createRow(0);
|
|
Row headerRow2 = sheet.createRow(1);
|
|
CellStyle cellStyle1 = wb.createCellStyle(); //쉼표들어간 숫자 양식
|
|
CellStyle cellStyle2 = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle2 = wb.createCellStyle();
|
|
CellStyle headerStyle3 = wb.createCellStyle();
|
|
|
|
XSSFDataFormat format = wb.createDataFormat();
|
|
cellStyle1.setDataFormat(format.getFormat("#,##0"));
|
|
cellStyle2.setDataFormat(format.getFormat("#,##0"));
|
|
cellStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle2.setBorderTop(BorderStyle.THIN);
|
|
headerStyle2.setBorderBottom(BorderStyle.THIN);
|
|
headerStyle2.setBorderLeft(BorderStyle.THIN);
|
|
headerStyle2.setBorderRight(BorderStyle.THIN);
|
|
headerStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle2.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle2.setFillForegroundColor((short)3);
|
|
headerStyle2.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
headerStyle.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle.setFillForegroundColor((short)3);
|
|
headerStyle.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
headerStyle3.setBorderTop(BorderStyle.THIN);
|
|
headerStyle3.setBorderBottom(BorderStyle.THIN);
|
|
headerStyle3.setBorderLeft(BorderStyle.THIN);
|
|
headerStyle3.setBorderRight(BorderStyle.THIN);
|
|
headerStyle3.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle3.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle3.setFillForegroundColor((short)3);
|
|
headerStyle3.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
|
|
|
|
//로우그리기
|
|
for(int i=0; i<list.size(); i++) {
|
|
ParamMap rowData = list.get(i);
|
|
Row row = sheet.createRow(i+2);
|
|
|
|
for(int j=0; j<headers.length; j++) {
|
|
Cell cell = row.createCell(j);
|
|
|
|
|
|
if(columnType[j].equalsIgnoreCase("Int")) {
|
|
cell.setCellValue(rowData.getInt(headers[j]));
|
|
cell.setCellStyle(cellStyle2);
|
|
} else if(columnType[j].equalsIgnoreCase("String")) {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
} else {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
}
|
|
}
|
|
}
|
|
|
|
//헤더
|
|
for(int j=0; j<headerNames.length; j++) {
|
|
Cell cell = headerRow.createCell(j);
|
|
cell.setCellValue(headerNames[j]);
|
|
cell.setCellStyle(headerStyle3);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) + 1000);
|
|
}
|
|
sheet.addMergedRegion(new CellRangeAddress(0,0,0,4));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,0,5,9));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,0,10,15));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,0,16,21));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,0,22,26));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,0,27,29));
|
|
for(int j=0; j<headerNames2.length; j++) {
|
|
Cell cell = headerRow2.createCell(j);
|
|
cell.setCellValue(headerNames2[j]);
|
|
cell.setCellStyle(headerStyle2);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) + 1000);
|
|
}
|
|
//엑셀이름 한글깨짐방지
|
|
String outputFileName = new String(excelFileName.getBytes("KSC5601"), "8859_1");
|
|
|
|
response.setHeader("Set-Cookie", "fileDownload=true; path=/");
|
|
response.setHeader("Content-Disposition", String.format("attachment; filename=\""+outputFileName+"_"+Utils.getTimeStampString("yyyyMMdd_HHmm")+".xlsx\""));
|
|
|
|
wb.write(response.getOutputStream());
|
|
wb.close();
|
|
} else {
|
|
createNoDataAlert(response);
|
|
}
|
|
|
|
}
|
|
|
|
public static void partInfolistToExcel(List<PartInfo> partInfoList, HttpServletResponse response, String[] headers,
|
|
String[] headerNames,String[] headerNames2,String[] headerNames3, String[] columnType, String sheetName, String excelFileName) throws IOException {
|
|
if(Utils.isNotEmpty(partInfoList)) {
|
|
// 메모리에 100개의 행을 유지합니다. 행의 수가 넘으면 디스크에 적습니다.
|
|
XSSFWorkbook wb = new XSSFWorkbook();
|
|
Sheet sheet = wb.createSheet(sheetName);
|
|
Row headerRow = sheet.createRow(0);
|
|
Row headerRow2 = sheet.createRow(1);
|
|
Row headerRow3 = sheet.createRow(2);
|
|
CellStyle cellStyle1 = wb.createCellStyle(); //쉼표들어간 숫자 양식
|
|
CellStyle cellStyle2 = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle2 = wb.createCellStyle();
|
|
CellStyle headerStyle3 = wb.createCellStyle();
|
|
|
|
XSSFDataFormat format = wb.createDataFormat();
|
|
cellStyle1.setAlignment(HorizontalAlignment.CENTER);
|
|
cellStyle2.setDataFormat(format.getFormat("#,##0"));
|
|
cellStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle2.setBorderTop(BorderStyle.THIN);
|
|
headerStyle2.setBorderBottom(BorderStyle.THIN);
|
|
headerStyle2.setBorderLeft(BorderStyle.THIN);
|
|
headerStyle2.setBorderRight(BorderStyle.THIN);
|
|
headerStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle2.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle2.setFillForegroundColor((short)3);
|
|
headerStyle2.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
headerStyle.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle.setFillForegroundColor((short)3);
|
|
headerStyle.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
headerStyle3.setBorderTop(BorderStyle.THIN);
|
|
headerStyle3.setBorderBottom(BorderStyle.THIN);
|
|
headerStyle3.setBorderLeft(BorderStyle.THIN);
|
|
headerStyle3.setBorderRight(BorderStyle.THIN);
|
|
headerStyle3.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle3.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle3.setFillForegroundColor((short)3);
|
|
headerStyle3.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
|
|
//로우그리기
|
|
for(int i=0; i<partInfoList.size(); i++) {
|
|
ParamMap rowData = new ParamMap();
|
|
Row row = sheet.createRow(i+3);
|
|
rowData.set("mgt_organ", partInfoList.get(i).getMgtOrgan());
|
|
rowData.set("land_police", partInfoList.get(i).getLandPolice());
|
|
rowData.set("terminal_nm", partInfoList.get(i).getTerminalNm());
|
|
rowData.set("mp_work_type", partInfoList.get(i).getMpWorkType());
|
|
rowData.set("mp_people_cnt", partInfoList.get(i).getMpPeopleCnt());
|
|
rowData.set("mp_description", partInfoList.get(i).getMpDescription());
|
|
rowData.set("pl_work_type", partInfoList.get(i).getPlWorkType());
|
|
rowData.set("pl_people_cnt", partInfoList.get(i).getPlPeopleCnt());
|
|
rowData.set("pl_description", partInfoList.get(i).getPlDescription());
|
|
rowData.set("pi_manager_name", partInfoList.get(i).getPiManagerName());
|
|
if(partInfoList.get(i).getRentType().equals("Y")) {
|
|
rowData.set("rent_price", partInfoList.get(i).getRentPrice().toString()+"만");
|
|
}else {
|
|
rowData.set("rent_price", "무상");
|
|
}
|
|
if(partInfoList.get(i).getUtilityType().equals("Y")) {
|
|
rowData.set("utility_price", partInfoList.get(i).getUtilityPrice().toString()+"만");
|
|
}else {
|
|
rowData.set("utility_price", "무상");
|
|
}
|
|
rowData.set("wrt_dt", partInfoList.get(i).getWrtDt().format(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
|
|
for(int j=0; j<headers.length; j++) {
|
|
Cell cell = row.createCell(j);
|
|
|
|
if(columnType[j].equalsIgnoreCase("Int")) {
|
|
cell.setCellValue(rowData.getInt(headers[j]));
|
|
cell.setCellStyle(cellStyle2);
|
|
} else if(columnType[j].equalsIgnoreCase("String")) {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
cell.setCellStyle(cellStyle1);
|
|
} else {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
cell.setCellStyle(cellStyle1);
|
|
}
|
|
}
|
|
|
|
}
|
|
//헤더
|
|
for(int j=0; j<headerNames.length; j++) {
|
|
Cell cell = headerRow.createCell(j);
|
|
cell.setCellValue(headerNames[j]);
|
|
cell.setCellStyle(headerStyle3);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) + 1024);
|
|
}
|
|
|
|
for(int j=0; j<headerNames2.length; j++) {
|
|
Cell cell = headerRow2.createCell(j);
|
|
cell.setCellValue(headerNames2[j]);
|
|
cell.setCellStyle(headerStyle2);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) + 1024);
|
|
}
|
|
for(int j=0; j<headerNames3.length; j++) {
|
|
Cell cell = headerRow3.createCell(j);
|
|
cell.setCellValue(headerNames3[j]);
|
|
cell.setCellStyle(headerStyle2);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) + 1024);
|
|
}
|
|
sheet.addMergedRegion(new CellRangeAddress(0,2,0,0));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,2,1,1));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,2,2,2));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,0,3,5));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,0,6,8));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,1,9,12));
|
|
|
|
//엑셀이름 한글깨짐방지
|
|
String outputFileName = new String(excelFileName.getBytes("KSC5601"), "8859_1");
|
|
|
|
response.setHeader("Set-Cookie", "fileDownload=true; path=/");
|
|
response.setHeader("Content-Disposition", String.format("attachment; filename=\""+outputFileName+"_"+Utils.getTimeStampString("yyyyMMdd_HHmm")+".xlsx\""));
|
|
|
|
wb.write(response.getOutputStream());
|
|
wb.close();
|
|
} else {
|
|
createNoDataAlert(response);
|
|
}
|
|
}
|
|
|
|
public static void partWorkListToExcel(List<PartWork> partWorkList, List<CodeMgt> pwtList, HttpServletResponse response, String[] headers,
|
|
String[] headerNames, String[] headerNames2, String[] columnType, String sheetName, String excelFileName) throws IOException {
|
|
if(Utils.isNotEmpty(partWorkList)) {
|
|
// 메모리에 100개의 행을 유지합니다. 행의 수가 넘으면 디스크에 적습니다.
|
|
XSSFWorkbook wb = new XSSFWorkbook();
|
|
Sheet sheet = wb.createSheet(sheetName);
|
|
Row headerRow = sheet.createRow(0);
|
|
Row headerRow2 = sheet.createRow(1);
|
|
CellStyle cellStyle1 = wb.createCellStyle(); //쉼표들어간 숫자 양식
|
|
CellStyle cellStyle2 = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle2 = wb.createCellStyle();
|
|
CellStyle headerStyle3 = wb.createCellStyle();
|
|
|
|
XSSFDataFormat format = wb.createDataFormat();
|
|
cellStyle1.setAlignment(HorizontalAlignment.CENTER);
|
|
cellStyle2.setDataFormat(format.getFormat("#,##0"));
|
|
cellStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle2.setBorderTop(BorderStyle.THIN);
|
|
headerStyle2.setBorderBottom(BorderStyle.THIN);
|
|
headerStyle2.setBorderLeft(BorderStyle.THIN);
|
|
headerStyle2.setBorderRight(BorderStyle.THIN);
|
|
headerStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle2.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle2.setFillForegroundColor((short)3);
|
|
headerStyle2.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
headerStyle.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle.setFillForegroundColor((short)3);
|
|
headerStyle.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
headerStyle3.setBorderTop(BorderStyle.THIN);
|
|
headerStyle3.setBorderBottom(BorderStyle.THIN);
|
|
headerStyle3.setBorderLeft(BorderStyle.THIN);
|
|
headerStyle3.setBorderRight(BorderStyle.THIN);
|
|
headerStyle3.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle3.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle3.setFillForegroundColor((short)3);
|
|
headerStyle3.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
//로우그리기
|
|
for(int i=0; i<partWorkList.size(); i++) {
|
|
ParamMap rowData = new ParamMap();
|
|
Row row = sheet.createRow(i+2);
|
|
rowData.set("terminal_nm", partWorkList.get(i).getTerminalNm());
|
|
rowData.set("wrt_nm", partWorkList.get(i).getWrtNm());
|
|
if(partWorkList.get(i).getWorkDt() != null) {
|
|
rowData.set("work_dt", partWorkList.get(i).getWorkDt().format(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
|
|
}else {
|
|
rowData.set("work_dt", "");
|
|
}
|
|
for(CodeMgt code: pwtList){
|
|
rowData.set("work_type_"+code.getItemCd(), partWorkList.get(i).getWorkType().equals(code.getItemCd())?"O":"");
|
|
}
|
|
rowData.set("description", partWorkList.get(i).getDescription());
|
|
rowData.set("file_cnt", partWorkList.get(i).getFileCnt()+"건");
|
|
rowData.set("wrt_dt", partWorkList.get(i).getWrtDt().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm")));
|
|
for(int j=0; j<headers.length; j++) {
|
|
Cell cell = row.createCell(j);
|
|
|
|
if(columnType[j].equalsIgnoreCase("Int")) {
|
|
cell.setCellValue(rowData.getInt(headers[j]));
|
|
cell.setCellStyle(cellStyle2);
|
|
} else if(columnType[j].equalsIgnoreCase("String")) {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
cell.setCellStyle(cellStyle1);
|
|
} else {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
cell.setCellStyle(cellStyle1);
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
//헤더
|
|
for(int j=0; j<headerNames.length; j++) {
|
|
Cell cell = headerRow.createCell(j);
|
|
cell.setCellValue(headerNames[j]);
|
|
cell.setCellStyle(headerStyle3);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) + 1024);
|
|
}
|
|
|
|
for(int j=0; j<headerNames2.length; j++) {
|
|
Cell cell = headerRow2.createCell(j);
|
|
cell.setCellValue(headerNames2[j]);
|
|
cell.setCellStyle(headerStyle2);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) + 1024);
|
|
}
|
|
sheet.addMergedRegion(new CellRangeAddress(0,1,0,0)); // ( 시작행, 종료행, 시작열, 종료열 )
|
|
sheet.addMergedRegion(new CellRangeAddress(0,1,1,1));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,1,2,2));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,0,3,8));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,1,9,9));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,1,10,10));
|
|
sheet.addMergedRegion(new CellRangeAddress(0,1,11,11));
|
|
|
|
//엑셀이름 한글깨짐방지
|
|
String outputFileName = new String(excelFileName.getBytes("KSC5601"), "8859_1");
|
|
|
|
response.setHeader("Set-Cookie", "fileDownload=true; path=/");
|
|
response.setHeader("Content-Disposition", String.format("attachment; filename=\""+outputFileName+"_"+Utils.getTimeStampString("yyyyMMdd_HHmm")+".xlsx\""));
|
|
|
|
wb.write(response.getOutputStream());
|
|
wb.close();
|
|
} else {
|
|
createNoDataAlert(response);
|
|
}
|
|
|
|
}
|
|
|
|
public static void cellPhoneListToExcel(List<CellPhone> cellPhoneList, HttpServletResponse response,
|
|
String[] headers, String[] headerNames, String[] columnType, String sheetName, String excelFileName) throws IOException {
|
|
if(Utils.isNotEmpty(cellPhoneList)) {
|
|
// 메모리에 100개의 행을 유지합니다. 행의 수가 넘으면 디스크에 적습니다.
|
|
XSSFWorkbook wb = new XSSFWorkbook();
|
|
Sheet sheet = wb.createSheet(sheetName);
|
|
Row headerRow = sheet.createRow(0);
|
|
CellStyle cellStyle1 = wb.createCellStyle(); //쉼표들어간 숫자 양식
|
|
CellStyle cellStyle2 = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle2 = wb.createCellStyle();
|
|
CellStyle headerStyle3 = wb.createCellStyle();
|
|
|
|
XSSFDataFormat format = wb.createDataFormat();
|
|
cellStyle1.setAlignment(HorizontalAlignment.CENTER);
|
|
cellStyle2.setDataFormat(format.getFormat("#,##0"));
|
|
cellStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle2.setBorderTop(BorderStyle.THIN);
|
|
headerStyle2.setBorderBottom(BorderStyle.THIN);
|
|
headerStyle2.setBorderLeft(BorderStyle.THIN);
|
|
headerStyle2.setBorderRight(BorderStyle.THIN);
|
|
headerStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle2.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle2.setFillForegroundColor((short)3);
|
|
headerStyle2.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
headerStyle.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle.setFillForegroundColor((short)3);
|
|
headerStyle.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
headerStyle3.setBorderTop(BorderStyle.THIN);
|
|
headerStyle3.setBorderBottom(BorderStyle.THIN);
|
|
headerStyle3.setBorderLeft(BorderStyle.THIN);
|
|
headerStyle3.setBorderRight(BorderStyle.THIN);
|
|
headerStyle3.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle3.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle3.setFillForegroundColor((short)3);
|
|
headerStyle3.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
//로우그리기
|
|
for(int i=0; i<cellPhoneList.size(); i++) {
|
|
ParamMap rowData = new ParamMap();
|
|
Row row = sheet.createRow(i+1);
|
|
rowData.set("phone_key", cellPhoneList.get(i).getPhoneKey());
|
|
rowData.set("sosok", cellPhoneList.get(i).getSosok());
|
|
rowData.set("tel_no", cellPhoneList.get(i).getTelNo());
|
|
rowData.set("user_nm", cellPhoneList.get(i).getUserNm());
|
|
rowData.set("ext_mail", cellPhoneList.get(i).getExtMail());
|
|
rowData.set("webex_no", cellPhoneList.get(i).getWebexNo());
|
|
rowData.set("katalk_id", cellPhoneList.get(i).getKatalkId());
|
|
|
|
for(int j=0; j<headers.length; j++) {
|
|
Cell cell = row.createCell(j);
|
|
|
|
if(columnType[j].equalsIgnoreCase("Int")) {
|
|
cell.setCellValue(rowData.getInt(headers[j]));
|
|
cell.setCellStyle(cellStyle2);
|
|
} else if(columnType[j].equalsIgnoreCase("String")) {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
cell.setCellStyle(cellStyle1);
|
|
} else {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
cell.setCellStyle(cellStyle1);
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
//헤더
|
|
for(int j=0; j<headerNames.length; j++) {
|
|
Cell cell = headerRow.createCell(j);
|
|
cell.setCellValue(headerNames[j]);
|
|
cell.setCellStyle(headerStyle3);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) + 1024);
|
|
}
|
|
|
|
//엑셀이름 한글깨짐방지
|
|
String outputFileName = new String(excelFileName.getBytes("KSC5601"), "8859_1");
|
|
|
|
response.setHeader("Set-Cookie", "fileDownload=true; path=/");
|
|
response.setHeader("Content-Disposition", String.format("attachment; filename=\""+outputFileName+"_"+Utils.getTimeStampString("yyyyMMdd_HHmm")+".xlsx\""));
|
|
|
|
wb.write(response.getOutputStream());
|
|
wb.close();
|
|
} else {
|
|
createNoDataAlert(response);
|
|
}
|
|
|
|
}
|
|
|
|
public static void useListToExcel(List<UseList> useExcelList, HttpServletResponse response, String[] headers,
|
|
String[] headerNames, String[] columnType, String sheetName, String excelFileName) throws IOException {
|
|
if(Utils.isNotEmpty(useExcelList)) {
|
|
// 메모리에 100개의 행을 유지합니다. 행의 수가 넘으면 디스크에 적습니다.
|
|
XSSFWorkbook wb = new XSSFWorkbook();
|
|
Sheet sheet = wb.createSheet(sheetName);
|
|
Row headerRow = sheet.createRow(0);
|
|
CellStyle cellStyle1 = wb.createCellStyle(); //쉼표들어간 숫자 양식
|
|
CellStyle cellStyle2 = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle2 = wb.createCellStyle();
|
|
CellStyle headerStyle3 = wb.createCellStyle();
|
|
|
|
XSSFDataFormat format = wb.createDataFormat();
|
|
cellStyle1.setAlignment(HorizontalAlignment.CENTER);
|
|
cellStyle2.setDataFormat(format.getFormat("#,##0"));
|
|
cellStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle2.setBorderTop(BorderStyle.THIN);
|
|
headerStyle2.setBorderBottom(BorderStyle.THIN);
|
|
headerStyle2.setBorderLeft(BorderStyle.THIN);
|
|
headerStyle2.setBorderRight(BorderStyle.THIN);
|
|
headerStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle2.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle2.setFillForegroundColor((short)3);
|
|
headerStyle2.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
headerStyle.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle.setFillForegroundColor((short)3);
|
|
headerStyle.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
headerStyle3.setBorderTop(BorderStyle.THIN);
|
|
headerStyle3.setBorderBottom(BorderStyle.THIN);
|
|
headerStyle3.setBorderLeft(BorderStyle.THIN);
|
|
headerStyle3.setBorderRight(BorderStyle.THIN);
|
|
headerStyle3.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle3.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle3.setFillForegroundColor((short)3);
|
|
headerStyle3.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
//로우그리기
|
|
for(int i=0; i<useExcelList.size(); i++) {
|
|
ParamMap rowData = new ParamMap();
|
|
Row row = sheet.createRow(i+1);
|
|
rowData.set("use_no", useExcelList.get(i).getUseNo());
|
|
rowData.set("sosok", useExcelList.get(i).getSosok());
|
|
|
|
if(useExcelList.get(i).getUseDt() != null) {
|
|
rowData.set("use_dt", useExcelList.get(i).getUseDt().format(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
|
|
}else {
|
|
rowData.set("use_dt", "");
|
|
}
|
|
if(useExcelList.get(i).getDetailType().equals("PVREUSE007") || useExcelList.get(i).getDetailType().equals("QIRUSE006")) {
|
|
rowData.set("detail_type_name", useExcelList.get(i).getDetailSelf());
|
|
}else {
|
|
rowData.set("detail_type_name", useExcelList.get(i).getDetailTypeName());
|
|
}
|
|
rowData.set("people_cnt", useExcelList.get(i).getPeopleCnt());
|
|
rowData.set("description", useExcelList.get(i).getDescription());
|
|
rowData.set("wrt_dt", useExcelList.get(i).getWrtDt().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm")));
|
|
for(int j=0; j<headers.length; j++) {
|
|
Cell cell = row.createCell(j);
|
|
|
|
if(columnType[j].equalsIgnoreCase("Int")) {
|
|
cell.setCellValue(rowData.getInt(headers[j]));
|
|
cell.setCellStyle(cellStyle2);
|
|
} else if(columnType[j].equalsIgnoreCase("String")) {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
cell.setCellStyle(cellStyle1);
|
|
} else {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
cell.setCellStyle(cellStyle1);
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
//헤더
|
|
for(int j=0; j<headerNames.length; j++) {
|
|
Cell cell = headerRow.createCell(j);
|
|
cell.setCellValue(headerNames[j]);
|
|
cell.setCellStyle(headerStyle3);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) + 1024);
|
|
}
|
|
|
|
//엑셀이름 한글깨짐방지
|
|
String outputFileName = new String(excelFileName.getBytes("KSC5601"), "8859_1");
|
|
|
|
response.setHeader("Set-Cookie", "fileDownload=true; path=/");
|
|
response.setHeader("Content-Disposition", String.format("attachment; filename=\""+outputFileName+"_"+Utils.getTimeStampString("yyyyMMdd_HHmm")+".xlsx\""));
|
|
|
|
wb.write(response.getOutputStream());
|
|
wb.close();
|
|
} else {
|
|
createNoDataAlert(response);
|
|
}
|
|
|
|
}
|
|
|
|
public static void icaDownExcel(HttpServletResponse response, Excel excel) throws IOException {
|
|
if (Utils.isNotEmpty(excel.getList())) {
|
|
// 메모리에 100개의 행을 유지합니다. 행의 수가 넘으면 디스크에 적습니다.
|
|
XSSFWorkbook wb = new XSSFWorkbook();
|
|
excel.defalutConfig(wb);
|
|
|
|
XSSFDataFormat format = wb.createDataFormat();
|
|
excel.getCellStyle1().setDataFormat(format.getFormat("#,##0"));
|
|
excel.getCellStyle2().setDataFormat(format.getFormat("#"));
|
|
excel.getHeaderStyle().setAlignment(HorizontalAlignment.CENTER);
|
|
excel.getHeaderStyle().setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
excel.getHeaderStyle().setFillForegroundColor((short)3);
|
|
excel.getHeaderStyle().setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
|
|
// 헤더 생성
|
|
createHeader(excel, excel.getHeaderNames(), excel.getHeaderStyle(), 0);
|
|
|
|
rowCreate(excel, 1, 0, 0);
|
|
|
|
//엑셀이름 한글깨짐방지
|
|
excelNameHangulBrokenPrevention(response, wb, excel);
|
|
} else {
|
|
// 데이터 없을 시 경고창 생성
|
|
createNoDataAlert(response);
|
|
}
|
|
}
|
|
|
|
private static void createNoDataAlert(HttpServletResponse response) throws IOException {
|
|
response.setHeader("Content-Type", "text/html; charset=UTF-8");
|
|
PrintWriter out = response.getWriter();
|
|
|
|
out.write("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\" \"http://www.w3.org/TR/html4/loose.dtd\">");
|
|
out.write("<html lang=\"ko\">");
|
|
out.write("<head>");
|
|
out.write("<script type=\"text/javascript\">");
|
|
out.write("alert('데이터가 없습니다.');");
|
|
out.write("history.back(-1);");
|
|
out.write("</script>");
|
|
out.write("</head>");
|
|
out.write("</html>");
|
|
|
|
out.flush();
|
|
out.close();
|
|
}
|
|
|
|
private static void excelNameHangulBrokenPrevention(HttpServletResponse response, XSSFWorkbook wb, Excel excel) throws IOException {
|
|
excel.setOutputFileName(new String(excel.getExcelFileName().getBytes("KSC5601"), "8859_1"));
|
|
response.setHeader("Set-Cookie", "fileDownload=true; path=/");
|
|
response.setHeader("Content-Disposition", String.format("attachment; filename=\""+excel.getOutputFileName()+"_"+Utils.getTimeStampString("yyyyMMdd_HHmm")+".xlsx\""));
|
|
|
|
wb.write(response.getOutputStream());
|
|
wb.close();
|
|
}
|
|
|
|
private static void createHeader(Excel excel, String[] headerNames, CellStyle headerStyle, int index) {
|
|
if (headerNames.length > 0) {
|
|
excel.setHeaderRow(excel.getSheet().createRow(index));
|
|
for(int j=0; j< headerNames.length; j++) {
|
|
Cell cell = excel.getHeaderRow().createCell(j);
|
|
cell.setCellValue(headerNames[j]);
|
|
cell.setCellStyle(headerStyle);
|
|
excel.getSheet().autoSizeColumn(j);
|
|
excel.getSheet().setColumnWidth(j, (excel.getSheet().getColumnWidth(j)) + 1024);
|
|
}
|
|
}
|
|
}
|
|
|
|
private static void rowCreate(Excel excel, int rownum, int startIndex, int endIndex){
|
|
int mergeCount = 1;
|
|
boolean mergeCheck = false;
|
|
|
|
for(int i=0; i<excel.getList().size(); i++) {
|
|
ParamMap rowData = excel.getList().get(i);
|
|
excel.setRow(excel.getSheet().createRow(i+rownum));
|
|
|
|
if (mergeCheck) {
|
|
mergeCount += 1;
|
|
} else {
|
|
mergeCount = 1;
|
|
}
|
|
|
|
for(int j=0; j<excel.getHeaders().length; j++) {
|
|
Cell cell = excel.getRow().createCell(j);
|
|
|
|
if (i > 0 && j > 0) {
|
|
if (rowData.get(excel.getHeaders()[0]).equals(excel.getList().get(i-1).get(excel.getHeaders()[0])) && !(j >= startIndex && j <= endIndex)) {
|
|
if (i < excel.getList().size()-1 && rowData.get(excel.getHeaders()[0]).equals(excel.getList().get(i+1).get(excel.getHeaders()[0]))) {
|
|
mergeCheck = true;
|
|
} else {
|
|
excel.getSheet().addMergedRegion(new CellRangeAddress(i+rownum-mergeCount, i+rownum, j, j));
|
|
mergeCheck = false;
|
|
}
|
|
}
|
|
}
|
|
|
|
if(excel.getColumnType()[j].equalsIgnoreCase("Money")) {
|
|
cell.setCellValue(rowData.getInt(excel.getHeaders()[j]));
|
|
cell.setCellStyle(excel.getCellStyle1());
|
|
} else if(excel.getColumnType()[j].equalsIgnoreCase("Int")) {
|
|
cell.setCellValue(rowData.getInt(excel.getHeaders()[j]));
|
|
cell.setCellStyle(excel.getCellStyle2());
|
|
} else if(excel.getColumnType()[j].equalsIgnoreCase("String")) {
|
|
cell.setCellValue(rowData.getString(excel.getHeaders()[j]));
|
|
} else {
|
|
cell.setCellValue(rowData.getString(excel.getHeaders()[j]));
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public static void ipShipDownExcel(List<ParamMap> ipShipList, HttpServletResponse response, String[] headers,
|
|
String[] headerNames, String[] columnType, String sheetName, String excelFileName) throws IOException {
|
|
DecimalFormat formatter3 = new DecimalFormat("#,##0.####");
|
|
if(Utils.isNotEmpty(ipShipList)) {
|
|
// 메모리에 100개의 행을 유지합니다. 행의 수가 넘으면 디스크에 적습니다.
|
|
XSSFWorkbook wb = new XSSFWorkbook();
|
|
Sheet sheet = wb.createSheet(sheetName);
|
|
Row headerRow = sheet.createRow(0);
|
|
CellStyle cellStyle1 = wb.createCellStyle(); //쉼표들어간 숫자 양식
|
|
CellStyle cellStyle2 = wb.createCellStyle();
|
|
CellStyle cellStyle3 = wb.createCellStyle();//숫자양식
|
|
CellStyle headerStyle = wb.createCellStyle(); //숫자양식
|
|
|
|
XSSFDataFormat format = wb.createDataFormat();
|
|
cellStyle1.setDataFormat(format.getFormat("#,##0"));
|
|
cellStyle2.setDataFormat(format.getFormat("#,##0"));
|
|
cellStyle3.setWrapText(true);
|
|
cellStyle1.setAlignment(HorizontalAlignment.CENTER);
|
|
cellStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
cellStyle3.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle.setFillForegroundColor((short)3);
|
|
headerStyle.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
headerStyle.setWrapText(true);
|
|
|
|
//로우그리기
|
|
for(int i=0; i<ipShipList.size(); i++) {
|
|
ParamMap rowData = ipShipList.get(i);
|
|
Row row = sheet.createRow(i+1);
|
|
rowData.set("hangro", rowData.get("start_point")+"/"+rowData.get("end_point")+System.lineSeparator()+"("+rowData.get("distance_nm")+","+rowData.get("distance_km")+")");
|
|
if(rowData.get("ship_weight") != null) {
|
|
rowData.set("ship_weight", formatter3.format(rowData.get("ship_weight")));
|
|
}
|
|
rowData.set("susong", "여객: "+rowData.get("passenger_cnt")+"명"+System.lineSeparator()+"화물 :"+rowData.get("freight_cnt")+"TEU");
|
|
|
|
for(int j=0; j<headers.length; j++) {
|
|
Cell cell = row.createCell(j);
|
|
|
|
if(columnType[j].equalsIgnoreCase("Money")) {
|
|
cell.setCellValue(rowData.getInt(headers[j]));
|
|
cell.setCellStyle(cellStyle1);
|
|
} else if(columnType[j].equalsIgnoreCase("double")) {
|
|
cell.setCellValue(rowData.getInt(headers[j]));
|
|
cell.setCellStyle(cellStyle2);
|
|
} else if(columnType[j].equalsIgnoreCase("String")) {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
cell.setCellStyle(cellStyle3);
|
|
} else {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
}
|
|
}
|
|
}
|
|
|
|
//헤더그리기
|
|
for(int j=0; j<headerNames.length; j++) {
|
|
Cell cell = headerRow.createCell(j);
|
|
cell.setCellValue(headerNames[j]);
|
|
cell.setCellStyle(headerStyle);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) +(short)1024);
|
|
}
|
|
|
|
|
|
//엑셀이름 한글깨짐방지
|
|
String outputFileName = new String(excelFileName.getBytes("KSC5601"), "8859_1");
|
|
|
|
response.setHeader("Set-Cookie", "fileDownload=true; path=/");
|
|
response.setHeader("Content-Disposition", String.format("attachment; filename=\""+outputFileName+"_"+Utils.getTimeStampString("yyyyMMdd_HHmm")+".xlsx\""));
|
|
|
|
wb.write(response.getOutputStream());
|
|
wb.close();
|
|
} else {
|
|
createNoDataAlert(response);
|
|
}
|
|
|
|
}
|
|
|
|
public static void copyNonNullProperties(Object src, Object target) {
|
|
BeanUtils.copyProperties(src, target, getNullPropertyNames(src));
|
|
}
|
|
|
|
public static String[] getNullPropertyNames (Object source) {
|
|
final BeanWrapper src = new BeanWrapperImpl(source);
|
|
java.beans.PropertyDescriptor[] pds = src.getPropertyDescriptors();
|
|
|
|
Set<String> emptyNames = new HashSet<>();
|
|
for(java.beans.PropertyDescriptor pd : pds) {
|
|
Object srcValue = src.getPropertyValue(pd.getName());
|
|
if (srcValue == null) emptyNames.add(pd.getName());
|
|
}
|
|
String[] result = new String[emptyNames.size()];
|
|
return emptyNames.toArray(result);
|
|
}
|
|
|
|
public static void policelistToExcel(List<UserInfo> policeList, HttpServletResponse response, String[] headers,
|
|
String[] headerNames, String[] columnType, String sheetName, String excelFileName) throws IOException {
|
|
if(Utils.isNotEmpty(policeList)) {
|
|
// 메모리에 100개의 행을 유지합니다. 행의 수가 넘으면 디스크에 적습니다.
|
|
XSSFWorkbook wb = new XSSFWorkbook();
|
|
Sheet sheet = wb.createSheet(sheetName);
|
|
Row headerRow = sheet.createRow(0);
|
|
CellStyle cellStyle1 = wb.createCellStyle(); //쉼표들어간 숫자 양식
|
|
CellStyle cellStyle2 = wb.createCellStyle(); //숫자양식
|
|
CellStyle headerStyle3 = wb.createCellStyle();
|
|
|
|
XSSFDataFormat format = wb.createDataFormat();
|
|
cellStyle1.setAlignment(HorizontalAlignment.CENTER);
|
|
cellStyle2.setDataFormat(format.getFormat("#,##0"));
|
|
cellStyle2.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle3.setBorderTop(BorderStyle.THIN);
|
|
headerStyle3.setBorderBottom(BorderStyle.THIN);
|
|
headerStyle3.setBorderLeft(BorderStyle.THIN);
|
|
headerStyle3.setBorderRight(BorderStyle.THIN);
|
|
headerStyle3.setAlignment(HorizontalAlignment.CENTER);
|
|
headerStyle3.setFillPattern(FillPatternType.SOLID_FOREGROUND);
|
|
headerStyle3.setFillForegroundColor((short)3);
|
|
headerStyle3.setFillForegroundColor(IndexedColors.LIME.getIndex());
|
|
headerStyle3.setWrapText(true);
|
|
//로우그리기
|
|
for(int i=0; i<policeList.size(); i++) {
|
|
ParamMap rowData = new ParamMap();
|
|
Row row = sheet.createRow(i+1);
|
|
rowData.set("rownum", policeList.get(i).getRownum());
|
|
rowData.set("title_cd", policeList.get(i).getTitleCd());
|
|
rowData.set("user_nm", policeList.get(i).getUserNm());
|
|
rowData.set("organ_nm", policeList.get(i).getOrganNm());
|
|
rowData.set("ofc_cd", policeList.get(i).getOfcCd());
|
|
if(policeList.get(i).getBirthDate() != null) {
|
|
rowData.set("birth_date", policeList.get(i).getBirthDate().format(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
|
|
}else {
|
|
rowData.set("birth_date", "");
|
|
}
|
|
rowData.set("sex", policeList.get(i).getSex());
|
|
if(policeList.get(i).getPoliceInDate() != null) {
|
|
rowData.set("police_in_date", policeList.get(i).getPoliceInDate().format(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
|
|
}else {
|
|
rowData.set("police_in_date", "");
|
|
}
|
|
if(policeList.get(i).getTitleInDate() != null) {
|
|
rowData.set("title_in_date", policeList.get(i).getTitleInDate().format(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
|
|
}else {
|
|
rowData.set("title_in_date", "");
|
|
}
|
|
if(policeList.get(i).getOfcInDate() != null) {
|
|
rowData.set("ofc_in_date", policeList.get(i).getOfcInDate().format(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
|
|
}else {
|
|
rowData.set("ofc_in_date", "");
|
|
}
|
|
rowData.set("outturn_cd", policeList.get(i).getOutturnCd());
|
|
rowData.set("job_in_cd", policeList.get(i).getJobInCd());
|
|
rowData.set("wrt_dt", policeList.get(i).getWrtDt().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm")));
|
|
for(int j=0; j<headers.length; j++) {
|
|
Cell cell = row.createCell(j);
|
|
if(columnType[j].equalsIgnoreCase("Int")) {
|
|
cell.setCellValue(rowData.getInt(headers[j]));
|
|
cell.setCellStyle(cellStyle2);
|
|
} else if(columnType[j].equalsIgnoreCase("String")) {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
cell.setCellStyle(cellStyle1);
|
|
} else {
|
|
cell.setCellValue(rowData.getString(headers[j]));
|
|
cell.setCellStyle(cellStyle1);
|
|
}
|
|
}
|
|
}
|
|
//헤더
|
|
for(int j=0; j<headerNames.length; j++) {
|
|
Cell cell = headerRow.createCell(j);
|
|
cell.setCellValue(headerNames[j]);
|
|
cell.setCellStyle(headerStyle3);
|
|
sheet.autoSizeColumn(j);
|
|
sheet.setColumnWidth(j, (sheet.getColumnWidth(j)) + 1024);
|
|
}
|
|
//엑셀이름 한글깨짐방지
|
|
String outputFileName = new String(excelFileName.getBytes("UTF-8"), "8859_1");
|
|
|
|
response.setHeader("Set-Cookie", "fileDownload=true; path=/");
|
|
response.setHeader("Content-Disposition", String.format("attachment; filename=\""+outputFileName+"_"+Utils.getTimeStampString("yyyyMMdd_HHmm")+".xlsx\""));
|
|
|
|
wb.write(response.getOutputStream());
|
|
wb.close();
|
|
} else {
|
|
createNoDataAlert(response);
|
|
}
|
|
|
|
}
|
|
|
|
public static String getClientIP(HttpServletRequest request) {
|
|
String ip = request.getHeader("X-Forwarded-For");
|
|
|
|
if (ip == null) {
|
|
ip = request.getHeader("Proxy-Client-IP");
|
|
}
|
|
if (ip == null) {
|
|
ip = request.getHeader("WL-Proxy-Client-IP");
|
|
}
|
|
if (ip == null) {
|
|
ip = request.getHeader("HTTP_CLIENT_IP");
|
|
}
|
|
if (ip == null) {
|
|
ip = request.getHeader("HTTP_X_FORWARDED_FOR");
|
|
}
|
|
if (ip == null) {
|
|
ip = request.getRemoteAddr();
|
|
}
|
|
|
|
return ip;
|
|
}
|
|
|
|
}
|