日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

java excel 注解_Java注解--实现简单读取excel

發(fā)布時間:2025/3/15 java 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java excel 注解_Java注解--实现简单读取excel 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

實現(xiàn)工具類

利用注解實現(xiàn)簡單的excel數(shù)據(jù)讀取,利用注解對類的屬性和excel中的表頭映射,使用Apache的poi就不用在業(yè)務代碼中涉及row,rows這些屬性了。

定義注解:

@Retention(RetentionPolicy.RUNTIME)

@Target(ElementType.FIELD)

public @interface Excel {

String name();

}

由于本例中只涉及根據(jù)Excel表頭部分對Excel進行解析,只定義了一個name作為和Excel表頭的隱射。

工具類完整代碼如下:

public class ExcelUtil {

Class clazz;

public ExcelUtil(Class clazz) {

this.clazz = clazz;

}

public List importExcel(String sheetName, InputStream input) {

int maxCol = 0;

List list = new ArrayList();

try {

Workbook workbook = WorkbookFactory.create(input);

Sheet sheet = workbook.getSheet(sheetName);

// 如果指定sheet名,則取指定sheet中的內(nèi)容.

if (!sheetName.trim().equals("")) {

sheet = workbook.getSheet(sheetName);

}

// 如果傳入的sheet名不存在則默認指向第1個sheet.

if (sheet == null) {

sheet = workbook.getSheetAt(0);

}

int rows = sheet.getPhysicalNumberOfRows();

// 有數(shù)據(jù)時才處理

if (rows > 0) {

List allFields = getMappedFiled(clazz, null);

// 定義一個map用于存放列的序號和field.

Map fieldsMap = new HashMap();

// 第一行為表頭

Row rowHead = sheet.getRow(0);

Map cellMap = new HashMap<>();

int cellNum = rowHead.getPhysicalNumberOfCells();

for (int i = 0; i < cellNum; i++){

cellMap.put(rowHead.getCell(i).getStringCellValue().toLowerCase(), i);

}

for (Field field : allFields) {

// 將有注解的field存放到map中.

if (field.isAnnotationPresent(Excel.class)) {

Excel attr = field.getAnnotation(Excel.class);

// 根據(jù)Name來獲取相應的failed

int col = cellMap.get(attr.name().toLowerCase());

field.setAccessible(true);

fieldsMap.put(col, field);

}

}

// 從第2行開始取數(shù)據(jù)

for (int i = 1; i < rows; i++) {

Row row = sheet.getRow(i);

T entity = null;

for (int j = 0; j < cellNum; j++) {

Cell cell = row.getCell(j);

if (cell == null) {

continue;

}

int cellType = cell.getCellType();

String c = "";

if (cellType == HSSFCell.CELL_TYPE_NUMERIC) {

DecimalFormat df = new DecimalFormat("0");

c = df.format(cell.getNumericCellValue());

} else if (cellType == HSSFCell.CELL_TYPE_BOOLEAN) {

c = String.valueOf(cell.getBooleanCellValue());

} else {

c = cell.getStringCellValue();

}

if (c == null || c.equals("")) {

continue;

}

entity = (entity == null ? clazz.newInstance() : entity);

// 從map中得到對應列的field.

Field field = fieldsMap.get(j);

if (field == null) {

continue;

}

// 取得類型,并根據(jù)對象類型設置值.

Class> fieldType = field.getType();

if (String.class == fieldType) {

field.set(entity, String.valueOf(c));

} else if ((Integer.TYPE == fieldType)

|| (Integer.class == fieldType)) {

field.set(entity, Integer.valueOf(c));

} else if ((Long.TYPE == fieldType)

|| (Long.class == fieldType)) {

field.set(entity, Long.valueOf(c));

} else if ((Float.TYPE == fieldType)

|| (Float.class == fieldType)) {

field.set(entity, Float.valueOf(c));

} else if ((Short.TYPE == fieldType)

|| (Short.class == fieldType)) {

field.set(entity, Short.valueOf(c));

} else if ((Double.TYPE == fieldType)

|| (Double.class == fieldType)) {

field.set(entity, Double.valueOf(c));

} else if (Character.TYPE == fieldType) {

if (c.length() > 0) {

field.set(entity, c.charAt(0));

}

}

}

if (entity != null) {

list.add(entity);

}

}

}

} catch (Exception e) {

e.printStackTrace();

}

return list;

}

/**

* 得到實體類所有通過注解映射了數(shù)據(jù)表的字段

*

* @param clazz

* @param fields

* @return

*/

private List getMappedFiled(Class clazz, List fields) {

if (fields == null) {

fields = new ArrayList();

}

// 得到所有定義字段

Field[] allFields = clazz.getDeclaredFields();

// 得到所有field并存放到一個list中.

for (Field field : allFields) {

if (field.isAnnotationPresent(Excel.class)) {

fields.add(field);

}

}

if (clazz.getSuperclass() != null

&& !clazz.getSuperclass().equals(Object.class)) {

getMappedFiled(clazz.getSuperclass(), fields);

}

return fields;

}

}

代碼很簡單,獲取sheet,解析第一行,并和實體類標有注解的字段一一對應,用hashMap記錄下來,然后循環(huán)取得Excel中剩下所有的數(shù)據(jù),根據(jù)map的對應關(guān)系將值set到對應字段。

基本使用

待解析表格如下:

定義實體類:

public class User {

@Excel(name = "filed1")

private String name;

@Excel(name = "filed2")

private String nameEn;

@Excel(name = "filed3")

private Integer age;

@Excel(name = "filed4")

private String six;

@Excel(name = "filed5")

private String weight;

// ...getter setter

}

使用工具類:

public static void main (String[] args) {

FileInputStream fileInputStream = null;

try {

fileInputStream = new FileInputStream("D://data.xlsx");

} catch (FileNotFoundException e) {

e.printStackTrace();

}

ExcelUtil util = new ExcelUtil<>(User.class);

List jalanHotelList = util.importExcel("user", fileInputStream);

// do something

}

利用這個思路可以擴展出導出excel功能,利用注解指定導出的excel表頭,甚至可以輕松控制excel表頭的顏色,合并屬性等等,在xdemo中有詳細復雜的示例,可以研究下。由于我的需求很簡單,就不整那么復雜啦。

總結(jié)

以上是生活随笔為你收集整理的java excel 注解_Java注解--实现简单读取excel的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。