|
|
|
@ -36,6 +36,7 @@ import org.apache.poi.ss.usermodel.VerticalAlignment;
@@ -36,6 +36,7 @@ import org.apache.poi.ss.usermodel.VerticalAlignment;
|
|
|
|
|
import org.apache.poi.ss.usermodel.Workbook; |
|
|
|
|
import org.apache.poi.ss.usermodel.WorkbookFactory; |
|
|
|
|
import org.apache.poi.ss.util.CellRangeAddressList; |
|
|
|
|
import org.apache.poi.util.IOUtils; |
|
|
|
|
import org.apache.poi.xssf.streaming.SXSSFWorkbook; |
|
|
|
|
import org.apache.poi.xssf.usermodel.XSSFClientAnchor; |
|
|
|
|
import org.apache.poi.xssf.usermodel.XSSFDataValidation; |
|
|
|
@ -179,7 +180,8 @@ public class ExcelUtil<T>
@@ -179,7 +180,8 @@ public class ExcelUtil<T>
|
|
|
|
|
throw new IOException("文件sheet不存在"); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
int rows = sheet.getPhysicalNumberOfRows(); |
|
|
|
|
// 获取最后一个非空行的行下标,比如总行数为n,则返回的为n-1
|
|
|
|
|
int rows = sheet.getLastRowNum(); |
|
|
|
|
|
|
|
|
|
if (rows > 0) |
|
|
|
|
{ |
|
|
|
@ -219,10 +221,15 @@ public class ExcelUtil<T>
@@ -219,10 +221,15 @@ public class ExcelUtil<T>
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
for (int i = 1; i < rows; i++) |
|
|
|
|
for (int i = 1; i <= rows; i++) |
|
|
|
|
{ |
|
|
|
|
// 从第2行开始取数据,默认第一行是表头.
|
|
|
|
|
Row row = sheet.getRow(i); |
|
|
|
|
// 判断当前行是否是空行
|
|
|
|
|
if (isRowEmpty(row)) |
|
|
|
|
{ |
|
|
|
|
continue; |
|
|
|
|
} |
|
|
|
|
T entity = null; |
|
|
|
|
for (Map.Entry<Integer, Field> entry : fieldsMap.entrySet()) |
|
|
|
|
{ |
|
|
|
@ -321,7 +328,7 @@ public class ExcelUtil<T>
@@ -321,7 +328,7 @@ public class ExcelUtil<T>
|
|
|
|
|
*/ |
|
|
|
|
public void exportExcel(HttpServletResponse response, List<T> list, String sheetName) throws IOException |
|
|
|
|
{ |
|
|
|
|
response.setContentType("application/vnd.ms-excel"); |
|
|
|
|
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); |
|
|
|
|
response.setCharacterEncoding("utf-8"); |
|
|
|
|
this.init(list, sheetName, Type.EXPORT); |
|
|
|
|
exportExcel(response.getOutputStream()); |
|
|
|
@ -335,7 +342,7 @@ public class ExcelUtil<T>
@@ -335,7 +342,7 @@ public class ExcelUtil<T>
|
|
|
|
|
*/ |
|
|
|
|
public void importTemplateExcel(HttpServletResponse response, String sheetName) throws IOException |
|
|
|
|
{ |
|
|
|
|
response.setContentType("application/vnd.ms-excel"); |
|
|
|
|
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); |
|
|
|
|
response.setCharacterEncoding("utf-8"); |
|
|
|
|
this.init(null, sheetName, Type.IMPORT); |
|
|
|
|
exportExcel(response.getOutputStream()); |
|
|
|
@ -346,32 +353,12 @@ public class ExcelUtil<T>
@@ -346,32 +353,12 @@ public class ExcelUtil<T>
|
|
|
|
|
* |
|
|
|
|
* @return 结果 |
|
|
|
|
*/ |
|
|
|
|
public void exportExcel(OutputStream outputStream) |
|
|
|
|
public void exportExcel(OutputStream out) |
|
|
|
|
{ |
|
|
|
|
try |
|
|
|
|
{ |
|
|
|
|
// 取出一共有多少个sheet.
|
|
|
|
|
double sheetNo = Math.ceil(list.size() / sheetSize); |
|
|
|
|
for (int index = 0; index <= sheetNo; index++) |
|
|
|
|
{ |
|
|
|
|
createSheet(sheetNo, index); |
|
|
|
|
|
|
|
|
|
// 产生一行
|
|
|
|
|
Row row = sheet.createRow(0); |
|
|
|
|
int column = 0; |
|
|
|
|
// 写入各个字段的列头名称
|
|
|
|
|
for (Object[] os : fields) |
|
|
|
|
{ |
|
|
|
|
Excel excel = (Excel) os[1]; |
|
|
|
|
this.createCell(excel, row, column++); |
|
|
|
|
} |
|
|
|
|
if (Type.EXPORT.equals(type)) |
|
|
|
|
{ |
|
|
|
|
fillExcelData(index, row); |
|
|
|
|
addStatisticsRow(); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
wb.write(outputStream); |
|
|
|
|
writeSheet(); |
|
|
|
|
wb.write(out); |
|
|
|
|
} |
|
|
|
|
catch (Exception e) |
|
|
|
|
{ |
|
|
|
@ -379,27 +366,35 @@ public class ExcelUtil<T>
@@ -379,27 +366,35 @@ public class ExcelUtil<T>
|
|
|
|
|
} |
|
|
|
|
finally |
|
|
|
|
{ |
|
|
|
|
if (wb != null) |
|
|
|
|
IOUtils.closeQuietly(wb); |
|
|
|
|
IOUtils.closeQuietly(out); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* 创建写入数据到Sheet |
|
|
|
|
*/ |
|
|
|
|
public void writeSheet() |
|
|
|
|
{ |
|
|
|
|
// 取出一共有多少个sheet.
|
|
|
|
|
double sheetNo = Math.ceil(list.size() / sheetSize); |
|
|
|
|
for (int index = 0; index <= sheetNo; index++) |
|
|
|
|
{ |
|
|
|
|
createSheet(sheetNo, index); |
|
|
|
|
|
|
|
|
|
// 产生一行
|
|
|
|
|
Row row = sheet.createRow(0); |
|
|
|
|
int column = 0; |
|
|
|
|
// 写入各个字段的列头名称
|
|
|
|
|
for (Object[] os : fields) |
|
|
|
|
{ |
|
|
|
|
try |
|
|
|
|
{ |
|
|
|
|
wb.close(); |
|
|
|
|
} |
|
|
|
|
catch (IOException e1) |
|
|
|
|
{ |
|
|
|
|
e1.printStackTrace(); |
|
|
|
|
} |
|
|
|
|
Excel excel = (Excel) os[1]; |
|
|
|
|
this.createCell(excel, row, column++); |
|
|
|
|
} |
|
|
|
|
if (outputStream != null) |
|
|
|
|
if (Type.EXPORT.equals(type)) |
|
|
|
|
{ |
|
|
|
|
try |
|
|
|
|
{ |
|
|
|
|
outputStream.close(); |
|
|
|
|
} |
|
|
|
|
catch (IOException e1) |
|
|
|
|
{ |
|
|
|
|
e1.printStackTrace(); |
|
|
|
|
} |
|
|
|
|
fillExcelData(index, row); |
|
|
|
|
addStatisticsRow(); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
@ -535,8 +530,7 @@ public class ExcelUtil<T>
@@ -535,8 +530,7 @@ public class ExcelUtil<T>
|
|
|
|
|
} |
|
|
|
|
else if (ColumnType.IMAGE == attr.cellType()) |
|
|
|
|
{ |
|
|
|
|
ClientAnchor anchor = new XSSFClientAnchor(0, 0, 0, 0, (short) cell.getColumnIndex(), cell.getRow().getRowNum(), (short) (cell.getColumnIndex() + 1), |
|
|
|
|
cell.getRow().getRowNum() + 1); |
|
|
|
|
ClientAnchor anchor = new XSSFClientAnchor(0, 0, 0, 0, (short) cell.getColumnIndex(), cell.getRow().getRowNum(), (short) (cell.getColumnIndex() + 1), cell.getRow().getRowNum() + 1); |
|
|
|
|
String imagePath = Convert.toStr(value); |
|
|
|
|
if (StringUtils.isNotEmpty(imagePath)) |
|
|
|
|
{ |
|
|
|
@ -546,7 +540,7 @@ public class ExcelUtil<T>
@@ -546,7 +540,7 @@ public class ExcelUtil<T>
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* 获取画布 |
|
|
|
|
*/ |
|
|
|
@ -1028,4 +1022,27 @@ public class ExcelUtil<T>
@@ -1028,4 +1022,27 @@ public class ExcelUtil<T>
|
|
|
|
|
} |
|
|
|
|
return val; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* 判断是否是空行 |
|
|
|
|
* |
|
|
|
|
* @param row 判断的行 |
|
|
|
|
* @return |
|
|
|
|
*/ |
|
|
|
|
private boolean isRowEmpty(Row row) |
|
|
|
|
{ |
|
|
|
|
if (row == null) |
|
|
|
|
{ |
|
|
|
|
return true; |
|
|
|
|
} |
|
|
|
|
for (int i = row.getFirstCellNum(); i < row.getLastCellNum(); i++) |
|
|
|
|
{ |
|
|
|
|
Cell cell = row.getCell(i); |
|
|
|
|
if (cell != null && cell.getCellType() != CellType.BLANK) |
|
|
|
|
{ |
|
|
|
|
return false; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
return true; |
|
|
|
|
} |
|
|
|
|
} |