From 4f0ab5fbe931949871b2a777c90f00f3661404c6 Mon Sep 17 00:00:00 2001 From: jinpengyong <jpy123456> Date: Wed, 13 Mar 2024 08:46:05 +0800 Subject: [PATCH] fix:走航日报补充提交 --- screen-api/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java | 90 +++++++++++++++++++++++++++++++-------------- 1 files changed, 62 insertions(+), 28 deletions(-) diff --git a/screen-api/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java b/screen-api/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java index 33c1ea6..4a52535 100644 --- a/screen-api/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java +++ b/screen-api/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java @@ -3,13 +3,11 @@ import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; - import com.moral.api.config.Interceptor.UserHelper; import com.moral.api.entity.*; import com.moral.api.mapper.DailyMapper; import com.moral.api.mapper.HistorySecondCruiserMapper; import com.moral.api.mapper.SpecialDeviceMapper; -import com.moral.api.mapper.SysDictTypeMapper; import com.moral.api.pojo.bo.ExcelBO; import com.moral.api.pojo.dto.historySecondCruiser.HistorySecondCruiserListDTO; import com.moral.api.pojo.dto.historySecondCruiser.HistorySecondCruiserResultCountDTO; @@ -30,7 +28,6 @@ import com.moral.util.FileUtils; import com.moral.util.GeodesyUtils; import com.moral.util.TokenUtils; - import org.apache.commons.collections4.CollectionUtils; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; @@ -38,9 +35,7 @@ import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Service; import org.springframework.util.ObjectUtils; -import org.springframework.util.StringUtils; import org.springframework.web.multipart.MultipartFile; - import java.io.File; import java.math.BigDecimal; import java.text.ParseException; @@ -210,7 +205,7 @@ }); } }else { - BigDecimal dataValue = Objects.nonNull(list.getDataValue())?BigDecimal.valueOf(Integer.parseInt(list.getDataValue())):BigDecimal.ZERO; + BigDecimal dataValue = Objects.nonNull(list.getDataValue())?BigDecimal.valueOf(Double.parseDouble(list.getDataValue())):BigDecimal.ZERO; result.forEach(it->{ it.setAvgNum(it.getAvgNum().add(dataValue)); }); @@ -224,8 +219,8 @@ private BigDecimal numAvg(List<String> list , BigDecimal num){ int nums = 1; for (int i=0;i<list.size();i=i+2){ - if(num.compareTo(BigDecimal.valueOf(Integer.parseInt(list.get(i))))>= 0 ){ - return num.add(BigDecimal.valueOf(Integer.parseInt(list.get(nums)))); + if(num.compareTo(BigDecimal.valueOf(Double.parseDouble(list.get(i))))>= 0 ){ + return num.add(BigDecimal.valueOf(Double.parseDouble(list.get(i+1)))); } nums+=2; } @@ -327,10 +322,11 @@ String type = params.get("type").toString(); String code = params.get("code").toString(); String area = params.get("area").toString(); + String mac = params.get("mac").toString(); rsMap.put("area",area); + rsMap.put("mac",mac.substring(9)); String value = JSON.toJSONString(rsMap); - String mac = params.get("mac").toString(); QueryWrapper<TbDaily> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("mac",mac); queryWrapper.likeRight("time",time1.substring(0,10)); @@ -446,29 +442,36 @@ /** * ��������������������� - * @param id + * @param ids * @return */ @Override - public DailyVo loadDaily(Integer id) { - ArrayList<String> rsList = new ArrayList<>(); - DailyVo dailyVo = new DailyVo(); - TbDaily tbDaily = dailyMapper.selectById(id); - if (tbDaily==null){ - return null; + public List<DailyVo> loadDaily(List<Integer> ids) { + ArrayList<DailyVo> dailyVos = new ArrayList<>(); + for (Integer id : ids) { + ArrayList<String> rsList = new ArrayList<>(); + DailyVo dailyVo = new DailyVo(); + TbDaily tbDaily = dailyMapper.selectById(id); + if (tbDaily==null){ + continue; + } + String images = tbDaily.getImages(); + if (!ObjectUtils.isEmpty(images)){ + String[] split = images.split(","); + List<String> list1 = Arrays.asList(split); + dailyVo.setImages(list1); + }else { + dailyVo.setImages(rsList); + } + String value = tbDaily.getValue(); + Map map = JSON.parseObject(value, Map.class); + List<String> list = (List<String>) map.get("time"); + String join = String.join("-", list); + map.put("time",join); + dailyVo.setCode(map); + dailyVos.add(dailyVo); } - String images = tbDaily.getImages(); - if (!ObjectUtils.isEmpty(images)){ - String[] split = images.split(","); - List<String> list1 = Arrays.asList(split); - dailyVo.setImages(list1); - }else { - dailyVo.setImages(rsList); - } - String value = tbDaily.getValue(); - Map map = JSON.parseObject(value, Map.class); - dailyVo.setCode(map); - return dailyVo; + return dailyVos; } /** @@ -750,4 +753,35 @@ } + + /** + * + */ + private double getDivisor(String code,double num){ + double rs = 0.0; + if (code.contains("-")){ + String data = code.substring(1); + rs = num - Double.parseDouble(data); + } else if (code.contains("*")){ + String data = code.substring(1); + rs = num * Double.parseDouble(data); + } else if (code.contains("/")){ + String data = code.substring(1); + rs = num / Double.parseDouble(data); + } else if (code.contains(",")){ + String[] split = code.split(","); + for (String s : split) { + String[] split1 = s.split("<"); + double sp1 = Double.parseDouble(split1[0]); + double sp2 = Double.parseDouble(split1[1]); + double sp3 = Double.parseDouble(split1[2]); + if (num>=sp1 && num<=sp2){ + rs = num + sp3; + } + } + }else { + rs = num + Double.parseDouble(code); + } + return rs; + } } -- Gitblit v1.8.0