| | |
| | | import com.core.common.R; |
| | | import com.zy.asrs.entity.*; |
| | | import com.zy.asrs.entity.param.OrderDomainParam; |
| | | import com.zy.asrs.entity.result.PakoutExcelVo; |
| | | import com.zy.asrs.entity.result.PakoutVo; |
| | | import com.zy.asrs.service.*; |
| | | import com.zy.common.web.BaseController; |
| | |
| | | import java.io.IOException; |
| | | import java.net.URLEncoder; |
| | | import java.util.*; |
| | | import java.util.stream.Collectors; |
| | | |
| | | @RestController |
| | | public class PakoutController extends BaseController { |
| | |
| | | .doWrite(pakoutVos); |
| | | } |
| | | |
| | | @RequestMapping(value = "/pakOut/exportExcel2/auth") |
| | | public void exportExcel2(HttpServletResponse response, @RequestParam String orderNo) throws IOException { |
| | | |
| | | //从数据库查询数据 |
| | | List<Pakout> list = pakoutService.selectList(new EntityWrapper<Pakout>().eq("doc_num",orderNo).orderBy("maktx")); |
| | | |
| | | List<PakoutExcelVo> pakOutExcelVos=new ArrayList<>(); |
| | | |
| | | for (Pakout pakOut: list) { |
| | | Pla pla = plaService.selectOne(new EntityWrapper<Pla>() |
| | | .eq("batch", pakOut.getBatch()) |
| | | .eq("package_no", pakOut.getBarcode()) |
| | | .eq("brand", pakOut.getMaktx())); |
| | | PakoutExcelVo pakOutVo = new PakoutExcelVo(); |
| | | BeanUtils.copyProperties(pla,pakOutVo); |
| | | BeanUtils.copyProperties(pakOut,pakOutVo); |
| | | pakOutExcelVos.add(pakOutVo); |
| | | } |
| | | |
| | | Map<String, List<PakoutExcelVo>> collect = pakOutExcelVos.stream().collect(Collectors.groupingBy(PakoutExcelVo::getBrand)); |
| | | List<PakoutExcelVo> newPakOutExcelVos=new ArrayList<>(); |
| | | |
| | | for(Map.Entry<String, List<PakoutExcelVo>> entry: collect.entrySet()) { |
| | | double sum = entry.getValue().stream().mapToDouble(PakoutExcelVo::getAnfme).sum(); |
| | | newPakOutExcelVos.addAll(entry.getValue()); |
| | | |
| | | PakoutExcelVo pakoutExcelVo = new PakoutExcelVo(); |
| | | pakoutExcelVo.setProDate("小计:"); |
| | | pakoutExcelVo.setAnfme(sum); |
| | | newPakOutExcelVos.add(pakoutExcelVo); |
| | | } |
| | | |
| | | response.setContentType("application/vnd.ms-excel"); |
| | | response.setCharacterEncoding("utf-8"); |
| | | String fileName = URLEncoder.encode("拣货单", "UTF-8"); |
| | | response.setHeader("Content-disposition", "attachment;filename=" + fileName+ orderNo + ".xlsx"); |
| | | |
| | | EasyExcel.write(response.getOutputStream(), PakoutExcelVo.class) |
| | | .registerWriteHandler(new LongestMatchColumnWidthStyleStrategy()) |
| | | .sheet("表1") |
| | | .doWrite(newPakOutExcelVos); |
| | | } |
| | | |
| | | } |