package com.ken.wms.common.util;
import org.apache.commons.lang3.math.NumberUtils;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFFont;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.core.io.ClassPathResource;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.util.*;
/**
* Excel -JavaBean 转换器
*
* @author Ken
* @since 2017/3/27.
*/
public class EJConvertor {
/**
* 默认配置文件名
*/
private static final String DEFAULT_CONFIG_FILE_NAME = "EJConvertorConfig.xml";
/**
* Entity 节点名称
*/
private static final String ENTITY_ELEMENT = "entity";
/**
* Property 节点名称
*/
private static final String PROPERTY_ELEMENT = "property";
/**
* Field 节点信息
*/
private static final String FIELD_ELEMENT = "field";
/**
* Value 节点信息
*/
private static final String VALUE_ELEMENT = "value";
/**
* class 属性
*/
private static final String CLASS_ATTRIBUTE = "class";
/**
* sheetName 属性
*/
private static final String SHEET_NAME_ATTRIBUTE = "sheetName";
/**
* boldHeading 属性
*/
private static final String BOLD_HEADING_ATTRIBUTE = "boldHeading";
/**
* JavaBean的映射信息
*/
private Map<String, MappingInfo> excelJavaBeanMap;
public EJConvertor() {
init(DEFAULT_CONFIG_FILE_NAME);
}
public EJConvertor(String filePath) {
init(filePath);
}
/**
* 初始化映射信息
*
* @param fileLocation 配置文件路径
*/
private void init(String fileLocation) {
try {
// 读取配置文件
File configFile = new ClassPathResource(fileLocation).getFile();
DocumentBuilder documentBuilder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
Document doc = documentBuilder.parse(configFile);
// 解析配置文件
this.excelJavaBeanMap = parseMappingInfo(doc);
} catch (ParserConfigurationException | SAXException | IOException e) {
e.printStackTrace();
}
}
/**
* 解析 Document root 下配置的所有 excel-javaBean 映射信息
*
* @param root Document 根节点
* @return 返回 excel-javaBean 映射信息
*/
private Map<String, MappingInfo> parseMappingInfo(Document root) {
// 获取 root 下的所有 entity 节点
NodeList entities = root.getElementsByTagName(ENTITY_ELEMENT);
// 创建承载 MappingInfo 信息的Map
Map<String, MappingInfo> mappingInfoMap = new HashMap<>(entities.getLength());
// 解析 entity 节点
for (int index = 0; index < entities.getLength(); index++) {
// 创建 mappingInfo
MappingInfo mappingInfo = new MappingInfo();
// 解析节点信息
Node entityNode = entities.item(index);
if (entityNode.getNodeType() == Node.ELEMENT_NODE) {
Element entityElement = (Element) entityNode;
parseEntityElement(entityElement, mappingInfo);
}
// 保存节点信息
mappingInfoMap.put(mappingInfo.getClassName(), mappingInfo);
}
return mappingInfoMap;
}
/**
* 解析 entity 节点信息
*
* @param entityElement entity 节点
* @param mappingInfo 本 entity 节点包含的映射信息
*/
private void parseEntityElement(Element entityElement, MappingInfo mappingInfo) {
// 解析 entity 的 class 属性
String className = entityElement.getAttribute(CLASS_ATTRIBUTE);
mappingInfo.setClassName(className);
// 解析 entity 的 sheetName 属性
if (entityElement.hasAttribute(SHEET_NAME_ATTRIBUTE))
mappingInfo.setSheetName(entityElement.getAttribute(SHEET_NAME_ATTRIBUTE));
// 解析 entity 的 boldHeading 属性
if (entityElement.hasAttribute(BOLD_HEADING_ATTRIBUTE)) {
String isBoldHeading = entityElement.getAttribute(BOLD_HEADING_ATTRIBUTE);
mappingInfo.setBoldHeading(isBoldHeading.equals("true"));
}
// 读取并解析 property 节点
NodeList properties = entityElement.getElementsByTagName(PROPERTY_ELEMENT);
for (int index = 0; index < properties.getLength(); index++) {
Node propertyNode = properties.item(index);
if (propertyNode.getNodeType() == Node.ELEMENT_NODE) {
Element propertyElement = (Element) propertyNode;
parsePropertyElement(propertyElement, mappingInfo);
}
}
}
/**
* 解析 property 节点信息
*
* @param propertyElement property 节点
* @param mappingInfo 承载映射信息
*/
private void parsePropertyElement(Element propertyElement, MappingInfo mappingInfo) {
NodeList infoNodes = propertyElement.getChildNodes();
String field = null;
String value = null;
for (int infoNode_index = 0; infoNode_index < infoNodes.getLength(); infoNode_index++) {
Node infoNode = infoNodes.item(infoNode_index);
if (infoNode.getNodeName().equals(FIELD_ELEMENT))
field = infoNode.getTextContent();
if (infoNode.getNodeName().equals(VALUE_ELEMENT))
value = infoNode.getTextContent();
}
// 添加到映射信息中
if (field != null && value != null) {
mappingInfo.addFieldValueMapping(field, value);
mappingInfo.addValueFieldMapping(value, field);
}
}
/**
* 讀取 Excel 文件中的内容 Excel 文件中的每一行代表了一个对象实例,而行中各列的属性值对应为对象中的各个属性值
* 读取时,需要指定读取目标对象的类型以获得相关的映射信息,并且要求该对象已在配置文件中注册
*
* @param javaBeanClass 目标对象的类型
* @param file 数据来源的 Excel 文件
* @return 包含若干个目标对象实例的 List
*/
public <T> List<T> excelReader(Class<T> javaBeanClass, File file) {
// 参数检查
if (file == null || javaBeanClass == null)
return null;
// 初始化存放读取结果的 List
List<T> javaBeans = new ArrayList<>();
// 获取类名和映射信息
String className = javaBeanClass.getName();
MappingInfo mappingInfo = excelJavaBeanMap.get(className);
if (mappingInfo == null)
return null;
// 读取 Excel 文件
try (Workbook workbook = new XSSFWorkbook(new FileInputStream(file))) {
Sheet dataSheet = workbook.getSheetAt(0);
Row row;
Cell cell;
Iterator<Row> rowIterator = dataSheet.iterator();
Iterator<Cell> cellIterator;
// 读取第一行表头信息
if (!rowIterator.hasNext())
return null;
String fieldName;
Field fieldInstance;
Class<?> fieldClass;
List<String> fieldNameList = new ArrayList<>();// 目标对象的 field 名称列表
List<Class<?>> fieldClassList = new ArrayList<>();// 目标对象 field 类型列表
row = rowIterator.next();
cellIterator = row.iterator();
while (cellItera
没有合适的资源?快使用搜索试试~ 我知道了~
基于JavaWeb实现的食品仓库管理系统源码+数据库
共187个文件
java:92个
xml:22个
jsp:18个
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 147 浏览量
2023-12-13
17:08:29
上传
评论
收藏 1.08MB ZIP 举报
温馨提示
基于JavaWeb实现的食品仓库管理系统源码+数据库
资源推荐
资源详情
资源评论
收起资源包目录
基于JavaWeb实现的食品仓库管理系统源码+数据库 (187个子文件)
bootstrap.css 144KB
bootstrap.min.css 120KB
bootstrap-theme.css 26KB
bootstrap-theme.min.css 23KB
jquery-ui.css 20KB
bootstrap-datetimepicker.min.css 11KB
bootstrap-table.css 7KB
jquery.mloading.css 2KB
mainPage.css 544B
bootstrapValidator.min.css 488B
login.css 183B
glyphicons-halflings-regular.eot 20KB
.gitignore 79B
404Error.html 345B
500Error.html 345B
EJConvertor.java 24KB
StorageManageServiceImpl.java 19KB
StockRecordManageServiceImpl.java 18KB
StorageManageHandler.java 15KB
RepositoryAdminManageServiceImpl.java 15KB
RepositoryManageServiceImpl.java 13KB
SystemLogServiceImpl.java 12KB
SupplierManageServiceImpl.java 11KB
CustomerManageServiceImpl.java 11KB
RepositoryManageHandler.java 11KB
GoodsManageServiceImpl.java 11KB
RepositoryAdminManageHandler.java 11KB
CustomerManageHandler.java 10KB
SupplierManageHandler.java 10KB
GoodsManageHandler.java 10KB
AccountHandler.java 9KB
StockRecordManageHandler.java 9KB
UserInfoServiceImpl.java 9KB
SystemLogHandler.java 6KB
StorageManageService.java 6KB
KickoutSessionControlFilter.java 5KB
MapperTest.java 5KB
RepositoryAdminManageService.java 4KB
ExtendFormAuthenticationFilter.java 4KB
RepositoryService.java 4KB
UserAuthorizingRealm.java 4KB
SupplierManageService.java 3KB
SystemLogService.java 3KB
CustomerManageService.java 3KB
FilterChainDefinitionMapBuilder.java 3KB
GoodsManageService.java 3KB
CaptchaGenerator.java 3KB
AccountServiceImpl.java 3KB
StockRecordDTO.java 3KB
StockOutDO.java 2KB
StockInDO.java 2KB
StockRecordManageService.java 2KB
UserInfoDTO.java 2KB
StockInMapper.java 2KB
StockOutMapper.java 2KB
StorageMapper.java 2KB
Response.java 2KB
UserOperationLogging.java 2KB
UserOperationRecordDTO.java 2KB
UserOperationRecordDO.java 2KB
AccessRecordDO.java 2KB
AccessRecordDTO.java 2KB
UserInfoService.java 2KB
ServiceLogging.java 2KB
SessionListener.java 2KB
CustomerMapper.java 2KB
SupplierMapper.java 2KB
Storage.java 2KB
RepositoryAdminMapper.java 2KB
RepositoryAdmin.java 1KB
Repository.java 1KB
FileSourceHandler.java 1KB
GoodsMapper.java 1KB
UserInfoDO.java 1KB
RepositoryMapper.java 1KB
Supplier.java 1KB
Customer.java 1KB
GlobalExceptionHandler.java 1KB
UserInfoMapper.java 1KB
AnyOfRolesAuthorizationFilter.java 1KB
RolePermissionDO.java 1KB
AccessRecordMapper.java 1KB
MD5Util.java 1KB
UserOperationRecordMapper.java 1KB
Goods.java 1009B
PageForwardHandler.java 945B
RoleDO.java 863B
FileUtil.java 831B
UserPermissionMapper.java 767B
User.java 755B
BusinessException.java 695B
UserAccountServiceException.java 674B
RepositoryAdminManageServiceException.java 595B
StockRecordManageServiceException.java 572B
SystemLogServiceException.java 534B
UserInfoServiceException.java 518B
MyTest.java 466B
RepositoryManageServiceException.java 448B
CustomerManageServiceException.java 442B
StorageManageServiceException.java 442B
共 187 条
- 1
- 2
资源评论
云哲-吉吉2021
- 粉丝: 3318
- 资源: 1130
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功