package com.java110.api.importData.adapt; import com.alibaba.fastjson.JSONObject; import com.java110.api.importData.DefaultImportDataAdapt; import com.java110.api.importData.IImportDataCleaningAdapt; import com.java110.dto.owner.OwnerCarDto; import com.java110.dto.system.ComponentValidateResult; import com.java110.intf.user.IOwnerV1InnerServiceSMO; import com.java110.utils.util.Assert; import com.java110.utils.util.DateUtil; import com.java110.utils.util.ImportExcelUtils; import com.java110.utils.util.StringUtil; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.text.ParseException; import java.util.ArrayList; import java.util.List; @Service("importOwnerCarDataCleaning") public class ImportOwnerCarDataCleaningAdapt extends DefaultImportDataAdapt implements IImportDataCleaningAdapt { @Autowired private IOwnerV1InnerServiceSMO ownerV1InnerServiceSMOImpl; @Override public List analysisExcel(Workbook workbook, JSONObject paramIn, ComponentValidateResult result) throws Exception{ List ownerCars = new ArrayList(); //封装对象 getOwnerCars(workbook, ownerCars, result); //数据格式校验 validateCarInfo(ownerCars); return ownerCars; } /** * 获取业主车辆信息 * * @param workbook * @param ownerCars */ private void getOwnerCars(Workbook workbook, List ownerCars, ComponentValidateResult result) throws ParseException { Sheet sheet = null; sheet = ImportExcelUtils.getSheet(workbook, "业主车辆信息"); List oList = ImportExcelUtils.listFromSheet(sheet); OwnerCarDto importOwnerCar = null; for (int osIndex = 0; osIndex < oList.size(); osIndex++) { Object[] os = oList.get(osIndex); if (osIndex == 0 || osIndex == 1) { // 第一行是 头部信息 直接跳过 continue; } if (StringUtil.isNullOrNone(os[8])) { continue; } Assert.hasValue(os[8], (osIndex + 1) + "行车牌号不能为空"); Assert.hasValue(os[10], (osIndex + 1) + "行业主不能为空"); // Assert.hasValue(os[11], (osIndex + 1) + "行手机号不能为空"); // Assert.hasValue(os[3], (osIndex + 1) + "车辆品牌不能为空"); // Assert.hasValue(os[4], (osIndex + 1) + "车辆类型不能为空"); // Assert.hasValue(os[5], (osIndex + 1) + "车牌类型不能为空"); // Assert.hasValue(os[6], (osIndex + 1) + "颜色不能为空"); // Assert.hasValue(os[7], (osIndex + 1) + "停车场不能为空"); // Assert.hasValue(os[9], (osIndex + 1) + "车位不能为空"); if(os.length > 13) { Assert.hasValue(os[14], (osIndex + 1) + "行起租时间不能为空"); }else if(os.length > 14) { Assert.hasValue(os[15], (osIndex + 1) + "行截止时间不能为空"); } try { importOwnerCar.setCommunityId(os[1].toString()); } catch (Exception e) { throw new IllegalArgumentException("请输入小区编码"); } // Assert.hasValue(os[12], (osIndex + 1) + "停车场类型不能为空"); String startTime = os.length >= 14 && os[14] != null ? excelDoubleToDate(os[14].toString()):""; String endTime = os.length >= 15 && os[15] != null ? excelDoubleToDate(os[15].toString()):""; // Assert.isDate(startTime, DateUtil.DATE_FORMATE_STRING_B, (osIndex + 1) + "行开始时间格式错误 请填写YYYY-MM-DD文本格式"); // Assert.isDate(endTime, DateUtil.DATE_FORMATE_STRING_B, (osIndex + 1) + "行结束时间格式错误 请填写YYYY-MM-DD文本格式"); importOwnerCar = new OwnerCarDto(); importOwnerCar.setCarNum(os[8].toString().trim()); importOwnerCar.setOwnerName(os[10].toString().trim()); importOwnerCar.setLink(os.length <= 11 || os[11] == null ? "" : os[11].toString().trim()); // importOwnerCar.setCarBrand(os.length <= 3 || os[3] == null ? "" : os[3].toString().trim()); // importOwnerCar.setCarType(os.length <= 4 || os[4] == null ? "" : os[4].toString().trim()); // importOwnerCar.setLeaseType(os.length <= 5 || os[5] == null ? "" : os[5].toString().trim()); // importOwnerCar.setCarColor(os.length <= 6 || os[6] == null ? "" : os[6].toString().trim()); // importOwnerCar.setAreaNum(os.length <= 7 || os[7] == null ? "" : os[7].toString().trim()); //获取车位 String parkingLot = os.length <= 9 || os[9] == null ? "" : os[9].toString().trim(); importOwnerCar.setNum(parkingLot); importOwnerCar.setLogStartTime(startTime); importOwnerCar.setLogEndTime(endTime); importOwnerCar.setTypeCd(os.length <= 12 || os[12] == null ? "" : os[12].toString().trim()); importOwnerCar.setSpaceSate("S"); importOwnerCar.setUserId(result.getUserId()); ownerCars.add(importOwnerCar); } } /** * 数据格式校验 * * @param ownerCars */ private void validateCarInfo(List ownerCars) { for (OwnerCarDto ownerCarDto : ownerCars) { if ("".equals(ownerCarDto.getTypeCd()) || ownerCarDto.getTypeCd() == null) { continue; } if (!"1001".equals(ownerCarDto.getTypeCd()) && !"2001".equals(ownerCarDto.getTypeCd())) { throw new IllegalArgumentException(ownerCarDto.getCarNum() + "停车场类型应填写 1001(地上停车场)或者 2001 (地下停车场)"); } if (!"H".equals(ownerCarDto.getSpaceSate()) && !"S".equals(ownerCarDto.getSpaceSate())) { throw new IllegalArgumentException(ownerCarDto.getCarNum() + "车位状态应填写 S(出售)或者 H (出租)"); } } } }