当前位置: 首页 > news >正文

科技网站设计资讯移动端网站开发流程图

科技网站设计资讯,移动端网站开发流程图,网站制作学什么软件有哪些,汉口网站关键词排名背景 有这样一个场景#xff1a;前端下载Excel模板#xff0c;进行数据导入#xff0c;这个下载模板过程需要经过后端接口去数据库查询数据进行某些列的下拉数据填充#xff0c;下拉填充的数据过程中会出现错误String literals in formulas can’t be bigger than 255 cha…背景 有这样一个场景前端下载Excel模板进行数据导入这个下载模板过程需要经过后端接口去数据库查询数据进行某些列的下拉数据填充下拉填充的数据过程中会出现错误String literals in formulas can’t be bigger than 255 characters ASCII超过字符限制。 那么如何解决 解决方案 引入隐藏区域方式比如 可以创建一个隐藏Sheet专门存储该下拉填充数据需要使用到的地方进行引用该Sheet区域范围内容。 实现过程 下载接口 ApiOperation(value 下载EXCEL文件模板, produces MediaType.APPLICATION_OCTET_STREAM_VALUE)GetMapping(/download/{bizType})public void downloadExcel(HttpServletResponse response, PathVariable(bizType) String bizType) throws IOException {if (Arrays.stream(AliYunOssBizTypeEnum.values()).noneMatch(x - x.getCode().equals(bizType))) {throw new RuntimeException(类型有误!);}String fileName bizType .xls;InputStream inputStream aliYunOssService.download(template/ fileName);if (inputStream null) {throw new RuntimeException(获取阿里云文件模板失败请检查是否上传到阿里云OSS);}HSSFWorkbook wb new HSSFWorkbook(inputStream);Sheet sheet wb.getSheetAt(0);ExcelAbstractHandler handler ExcelHandlerFactory.getHandler(bizType);if (Objects.nonNull(handler)) {// 3. 创建隐藏工作表存储选项Sheet hiddenSheet wb.createSheet(HiddenSheet);wb.setSheetHidden(wb.getSheetIndex(hiddenSheet), true); // 隐藏工作表handler.handle(hiddenSheet, sheet, bizType);}ServletOutputStream output response.getOutputStream();response.setContentType(application/vnd.ms-excel);String desc Arrays.stream(AliYunOssBizTypeEnum.values()).filter(x - x.getCode().equals(bizType)).findFirst().get().getDesc();fileName URLEncoder.encode(desc, UTF-8);response.setHeader(Content-Disposition, attachment;filename fileName);wb.write(output);output.flush();output.close();wb.close();}抽象处理器 public abstract class ExcelAbstractHandler {public abstract void handle(Sheet hiddenSheet, Sheet sheet, String bizType);protected void buildDropdownData(Sheet mainSheet, ListString list, int col, String referenceRange) {if (CollectionUtil.isEmpty(list)) {return;}DataValidationHelper dvHelper mainSheet.getDataValidationHelper();DataValidationConstraint dvConstraint dvHelper.createFormulaListConstraint(referenceRange);CellRangeAddressList addressList new CellRangeAddressList(1, 2000, col, col);DataValidation validation dvHelper.createValidation(dvConstraint, addressList);mainSheet.addValidationData(validation);} } 处理工厂类 public class ExcelHandlerFactory {private static final MapString, ExcelAbstractHandler handlerMap new ConcurrentHashMap();public static ExcelAbstractHandler getHandler(String type) {return handlerMap.get(type);}public static void register(String type, ExcelAbstractHandler handler) {Assert.notNull(type, type cant be null);handlerMap.put(type, handler);} } 产品标准价格模板 Component Slf4j RequiredArgsConstructor public class ExcelProductPlatformPriceHandler extends ExcelAbstractHandler implements InitializingBean {private final BusinessBaseCountryMapper businessBaseCountryMapper;private final BusinessBaseShopPlatformMapper businessBaseShopPlatformMapper;Overridepublic void afterPropertiesSet() throws Exception {ExcelHandlerFactory.register(AliYunOssBizTypeEnum.PRODUCT_PLATFORM_PRICE.getCode(), this);}Overridepublic void handle(Sheet hiddenSheet, Sheet sheet, String bizType) {// 1.平台数据ListBusinessBaseShopPlatform platforms businessBaseShopPlatformMapper.selectList(Wrappers.lambdaQuery());ListString platformList platforms.stream().map(BusinessBaseShopPlatform::getPlatformName).collect(Collectors.toList());// 写入选项到隐藏工作表逐行填充for (int i 0; i platformList.size(); i) {Row row hiddenSheet.createRow(i);Cell cell row.createCell(0);cell.setCellValue(platformList.get(i));}// 定义引用区域例如Hidden!A1:A100String referenceRange hiddenSheet.getSheetName() !$A$1:$A$ platformList.size();buildDropdownData( sheet, platformList, 1, referenceRange);// 2.国家数据ListBusinessBaseCountry countries businessBaseCountryMapper.selectList(Wrappers.lambdaQuery());ListString countryList countries.stream().map(BusinessBaseCountry::getCountryName).collect(Collectors.toList());// 写入选项到隐藏工作表逐行填充int preCount platformList.size();for (int i preCount; i (preCount countryList.size()); i) {Row row hiddenSheet.createRow(i);Cell cell row.createCell(0);cell.setCellValue(countryList.get(i - preCount));}// 定义引用区域例如Hidden!A1:A100referenceRange hiddenSheet.getSheetName() !$A$ (preCount 1) :$A$ (preCount countryList.size());buildDropdownData(sheet, countryList, 2 , referenceRange);} } 最后 以上是一个简单操作下载导出模板并填充数据后下载模板接口经供参考
http://www.w-s-a.com/news/168968/

相关文章:

  • asp网站开发环境订单系统单页面网站怎么做
  • 山东网站建设都有那些企业推广策略
  • 网站开发文档是什么概念衣服销售网站建设规划书范文
  • 中国建筑装饰网官网企业网站设计优化公司
  • 南海建设工程交易中心网站c2c交易平台有哪些?
  • 有没有专业做网站架构图的软件番禺建设网站哪个好
  • 建立网站第一步整站seo优化公司
  • php网站开发文章管理系统wordpress 评论 顶踩 心 插件
  • 网站做百度收录的意义html网页设计代码作业代码
  • 网站推广怎么做 知乎衡水做网站开发的
  • 重庆忠县网站建设报价网页构建
  • 怎么自己做单页网站怎么在阿里做网站
  • 公司网站重新备案做电商没几个能赚钱的
  • 网站开发我们都能解决怎样做网站吸引客户
  • 网站首页图片切换代码wordpress minfy
  • 什么程序做网站收录好企业搭建网站的必要性
  • 建设网站主题建站必须要域名吗
  • 网站建设海报设计购物平台网站建设框架
  • 湖北在线网站建设建一个网站迈年
  • 上班自己花钱做的网站网站首页的动态怎么做
  • 台州网站建设哪家便宜沧州最新消息今天
  • 建设网站 请示 报告wordpress会员制
  • 青岛建网站人做网站怎么赚钱广告
  • 网站建设哪家好公司跨境电商展会2023
  • 设计大神云集的网站是南通市 网站设计
  • 心理咨询网站模板企业画册封面设计
  • 做网站 南京网站建设的重难点分析
  • 深圳做网站980移动网站开发语言
  • 网站评论怎么做seo关键词优化方法
  • 市级部门网站建设自评报告网站优化文章怎么做