用chatgpt实现 java导出excel复杂表。

记录一次使用chatgpt解决实际问题的,需求是在页面添加一个订单导出excel的功能,订单编号、订单明细,相同订单编号合并单元格,模板如下请添加图片描述
表头表尾不用说,
主要是表格内容部分,左边是订单编号,右边是订单明细,**这边难就难在一个订单编号可能存在多条明细,所以订单编号相同时需要合并单元格,**我们将需求整理清楚,下面就可以去询问chatgpt了,
首先我们试探性的问他:
在这里插入图片描述
他给出了回答,可以看出,他是完全知道怎么写的,接着我们就可以一步步继续深入问他了,下面就要带入自己的需求:
在这里插入图片描述
可以看到,我们这时将表单数据直接带进去询问,他依旧很清楚的给出了答案接下来我们继续深入询问他,创建的表单是否为父子结构,订单编号为父数据,其余为子列数据:
在这里插入图片描述
这时他依旧很清晰的给出了回答,并且他知道应该将父数据订单编号合并单元格。
真的很神奇,下面我们继续深入:我发现,他所有的数据都是根据我给的表单结构,自己造的,所以就询问他,如果数据是从数据库中取出来的,应该怎么写
在这里插入图片描述
他很快给出了回答,还是很正确的,但是这只是一个void main 测试方法,并不是我们想要的controller、service方法,于是我继续询问:如果是由页面发起请求,进行导出应该怎么写呢
在这里插入图片描述
这时他居然直接给出了正确的controller方法,现在已经离我们想要的代码非常接近了。
我们继续询问:让他加上表头、表尾、金额统计等等
在这里插入图片描述

在这里插入图片描述
接下来我们基本就可以进行手动测试了,测试过程中会出现各种问题,没关系。我们把发现的问题直接告诉他,让他修改就行,比如说我发现他忘记给内容添加表头了,直接就问他:
在这里插入图片描述
他很快会给出修改后的代码,当然,如果你代码测试中出现报错,也可以直接把代码和错误信息发过去问他:在这里插入图片描述
他很快会解决,并进行说明,总之你出现问题都可以直接询问,他都是能看得懂的,最终代码如下:

 @Overridepublic void exportBill(HttpServletResponse response, List<Integer> idList)  throws Exception{// 获取数据List<BillProductOderVO> orders = billProductService.getAllOrders(idList);// 创建工作簿Workbook workbook = new XSSFWorkbook();// 创建工作表Sheet sheet = workbook.createSheet("Sheet1");// 创建表头单元格样式CellStyle headerStyle = workbook.createCellStyle();headerStyle.setAlignment(HorizontalAlignment.CENTER);headerStyle.setVerticalAlignment(VerticalAlignment.CENTER);Font headerFont = workbook.createFont();headerFont.setBold(true);headerStyle.setFont(headerFont);// 创建正式内容单元格样式CellStyle contentStyle = workbook.createCellStyle();contentStyle.setAlignment(HorizontalAlignment.CENTER);contentStyle.setVerticalAlignment(VerticalAlignment.CENTER);contentStyle.setBorderTop(BorderStyle.THIN);contentStyle.setBorderBottom(BorderStyle.THIN);contentStyle.setBorderLeft(BorderStyle.THIN);contentStyle.setBorderRight(BorderStyle.THIN);// 添加大表头Row bigHeaderRow = sheet.createRow(0);bigHeaderRow.setHeightInPoints(30);Cell bigHeaderCell = bigHeaderRow.createCell(0);bigHeaderCell.setCellValue("销售出库单");bigHeaderCell.setCellStyle(headerStyle);sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, 7));// 添加第一行表头Row firstHeaderRow = sheet.createRow(1);firstHeaderRow.setHeightInPoints(20);List<String> firstHeader = Arrays.asList("日期:", DateUtil.getNowDayForChinese(), "单据编号:", "", "客户:","",  "制单人:",JWTUtil.getCurrentUser().getTokenRealName());for (int i = 0; i < firstHeader.size(); i++) {Cell cell = firstHeaderRow.createCell(i);cell.setCellValue(firstHeader.get(i));cell.setCellStyle(headerStyle);}// 添加第二行表头Row secondHeaderRow = sheet.createRow(2);secondHeaderRow.setHeightInPoints(20);List<String> secondHeader = Arrays.asList("联系人:","", "联系电话:","", "部门:","", "仓库:","");for (int i = 0; i < secondHeader.size(); i++) {Cell cell = secondHeaderRow.createCell(i);cell.setCellValue(secondHeader.get(i));cell.setCellStyle(headerStyle);}// 添加正式数据表头Row headerRow = sheet.createRow(3);headerRow.setHeightInPoints(20);List<String> headers = Arrays.asList("订单编号","存货名称", "规格型号", "计量单位", "数量", "单价", "金额","");for (int i = 0; i < headers.size(); i++) {Cell cell = headerRow.createCell(i);cell.setCellValue(headers.get(i));cell.setCellStyle(headerStyle);}// 创建数据行,并设置内容int rowIndex = 4;BigDecimal totalAmount = BigDecimal.ZERO;String lastParentId = "";Map<String, Integer> startRows = new HashMap<>();Map<String, Integer> endRows = new HashMap<>();for (BillProductOderVO order : orders) {String parentId = order.getOrderNo();if (parentId.equals(lastParentId)) {// 当前行与上一行的订单编号相同,不需要合并单元格,更新结束行Row row = sheet.createRow(rowIndex++);for (int i = 0; i < headers.size(); i++) {Cell subCell = row.createCell(i);subCell.setCellValue(getCellValue(order, i));subCell.setCellStyle(contentStyle);}endRows.put(parentId, rowIndex - 1);totalAmount = totalAmount.add(order.getAllMoney());} else {// 当前行与上一行的订单编号不同,更新起始行和结束行if (startRows.containsKey(lastParentId)) {int startRow = startRows.get(lastParentId);int endRow = endRows.get(lastParentId);if (endRow - startRow > 0) {// 只有当有两行及以上相同的订单编号时才需要合并单元格CellRangeAddress mergedRegion = new CellRangeAddress(startRow, endRow, 0, 0);sheet.addMergedRegion(mergedRegion);}}startRows.put(parentId, rowIndex);endRows.put(parentId, rowIndex);Row row = sheet.createRow(rowIndex++);for (int i = 0; i < headers.size(); i++) {Cell subCell = row.createCell(i);subCell.setCellValue(getCellValue(order, i));subCell.setCellStyle(contentStyle);}totalAmount = totalAmount.add(order.getAllMoney());}lastParentId = parentId;}// 对于最后一个订单号,需要进行合并单元格操作if (startRows.containsKey(lastParentId)) {int startRow = startRows.get(lastParentId);int endRow = endRows.get(lastParentId);if (endRow - startRow > 0) {// 只有当有两行及以上相同的订单编号时才需要合并单元格CellRangeAddress mergedRegion = new CellRangeAddress(startRow, endRow, 0, 0);sheet.addMergedRegion(mergedRegion);}}// 创建总金额行Row totalRow = sheet.createRow(rowIndex++);List<String> totalData = Arrays.asList("合计", "", "", "", "", "", String.valueOf(totalAmount),"");for (int i = 0; i < totalData.size(); i++) {Cell cell = totalRow.createCell(i);cell.setCellValue(totalData.get(i));cell.setCellStyle(contentStyle);}// 添加备注行Row remarkRow = sheet.createRow(rowIndex++);remarkRow.setHeightInPoints(20);Cell remarkCell = remarkRow.createCell(0);remarkCell.setCellValue("备注:");sheet.addMergedRegion(new CellRangeAddress(rowIndex - 1, rowIndex - 1, 0, headers.size() - 1));// 添加友情提示行Row promptRow = sheet.createRow(rowIndex++);promptRow.setHeightInPoints(20);Cell promptCell = promptRow.createCell(0);promptCell.setCellValue("友情提示:1、商品请当场验收,如有问题可即时更换或拒收2、易变质食品请妥善保管。");sheet.addMergedRegion(new CellRangeAddress(rowIndex - 1, rowIndex - 1, 0, headers.size() - 1));// 添加审核人、出库人、送货人、签收人行Row personRow = sheet.createRow(rowIndex++);personRow.setHeightInPoints(20);List<String> personData = Arrays.asList("审核人:", "出库人:", "送货人:", "签收人:");for (int i = 0; i < personData.size(); i++) {Cell cell = personRow.createCell(i * 2);cell.setCellValue(personData.get(i));sheet.addMergedRegion(new CellRangeAddress(rowIndex - 1, rowIndex - 1, i * 2, i * 2 + 1));}// 设置列宽for (int i = 0; i < headers.size(); i++) {if(i==1){sheet.setColumnWidth(i,60 * 256);}else {sheet.setColumnWidth(i, 20 * 256);}}// 设置响应头,告诉浏览器该文件为Excel格式response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");response.setHeader("Content-Disposition", "attachment; filename=\"orders.xlsx\"");// 将工作簿写入输出流,导出Excel文件OutputStream outputStream = response.getOutputStream();workbook.write(outputStream);workbook.close();outputStream.close();}private String getCellValue(BillProductOderVO order, int columnIndex) {switch (columnIndex) {case 0:return order.getOrderNo();case 1:return order.getProductName();case 2:return order.getSpec();case 3:return order.getUnit();case 4:return String.valueOf(order.getProductQuantity());case 5:return String.valueOf(order.getProductPrice());case 6:return String.valueOf(order.getAllMoney());default:return "";}}

不得不说,ChatGPT还是很强大的,这样的小功能如果你之前做过类似的,相信很快就能写出来,但是如果没有,一般人还是要花点时间去琢磨的。
ChatGPT的出现,真的很nice,不过所谓的程序员成功将自己卷没了这句话也并不正确,因为如果你根本是小白,连基本的代码都看不懂,哪怕给你ChatGPT也没法写功能。ChatGPT的关键就在于如何提问,对于一些小功能,使用它还是非常节省时间的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/46680.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

chatgpt赋能python:如何用Python制作表格

如何用Python制作表格 在编写数据分析报告或者制作科研论文时&#xff0c;经常需要使用表格来展示数据或者统计分析结果。在传统的Word或Excel软件中制作表格虽然简单易用&#xff0c;但是在大量的数据处理和自动化处理方面往往需要耗费大量的时间和精力。而Python作为一种高效…

小米辟谣武汉总部35岁以上员工只保留10%;丰田致歉!200万车主车辆数据遭泄露;jQuery 3.7.0 发布|极客头条...

「极客头条」—— 技术人员的新闻圈&#xff01; CSDN 的读者朋友们早上好哇&#xff0c;「极客头条」来啦&#xff0c;快来看今天都有哪些值得我们技术人关注的重要新闻吧。 整理 | 梦依丹 出品 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09; 一分钟速览新闻点&#…

BlockCity联手天涯社区,国内元宇宙行业蓄势待发

据传王兴投资的元宇宙项目BlockCity区块城市将联手天涯社区&#xff0c;旨在加快市场拓展步伐&#xff0c;这是最近ChatGPT火爆、元宇宙“遇冷”的背景下颇引人注意的消息。 BlockCity区块城市是新近才崭露头角的社交元宇宙平台&#xff0c;虽然有区块链资产、Web3社交和DAO&am…

突发!OPPO 关停“造芯”业务 ZEKU:近 3000 名员工“原地失业”,赔偿 N+3

整理 | 郑丽媛 出品 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09; 今天中午&#xff0c;据新浪科技报道&#xff0c;智能手机厂商 OPPO 将终止旗下芯片公司 ZEKU&#xff08;哲库&#xff09;业务&#xff1a; OPPO 称&#xff0c;面对全球经济、手机市场的不确定性&…

SegmentFault无法访问,因出现违规内容被网警要求停机!

作者&#xff1a;Hollis 公众号&#xff1a;Hollis 近日&#xff0c;有不少网友发现&#xff0c;开发者社区SegmentFault突然无法访问&#xff0c;用户进入网站会跳转到固定页面&#xff0c;并提示"维护中"。 &#xfffc;据官方微博发布公告称因为有用户发布了违规…

网警支队RFID机房资产管理系统解决方案-新导智能

某市网警支队作为全市负责公共信息网络安全监察、安全保护工作&#xff0c;负责监控信息网络有害信息和违法犯罪动态&#xff0c;组织、协调、指导和参与对网络违法犯罪案件的侦查工作&#xff0c;组织、指导和参与对计算机信息泄密、计算机病毒及其他计算机灾害事故的防范、处…

优盘中发现计算机病毒怎么办,【网警课堂】教你解决U盘使用中出现的各种问题!...

原标题&#xff1a;【网警课堂】教你解决U盘使用中出现的各种问题&#xff01; 在使用U盘的时候&#xff0c;我们经常会遇到各种问题。当我们遇到各种U盘问题时&#xff0c;该怎么办呢&#xff1f;今天文哥给大家分享一些解决U盘使用中出现相关问题的解决方法。 一、与U盘格式化…

Node.js力破江苏网警刑侦科推理试题

2019独角兽企业重金招聘Python工程师标准>>> 月前&#xff0c;江苏网警 在微博发布了一套《2018年刑侦科目推理试题》&#xff0c;可谓难倒了诸多英雄好汉&#xff0c;评论区内更是一片皮皮之音。 二向箔icon: 高考前班主任教过我们&#xff0c;遇上不会的题&#x…

微信转发的文件服务器留存吗,微信转发这种视频会感染病毒泄露隐私?网警的查证结果来了...

原标题:微信转发这种视频会感染病毒泄露隐私?网警的查证结果来了 最近网上流传一条“紧急通知”,称微信上流传着一些必须转发后才能继续观看的视频,这些视频其实被内植病毒,一旦转发,机主隐私立马被泄露。 真有这么可怕? 不少转发过此类视频的网友非常担心。 目前,多地…

计算机网络日志查询,系统资源管理_百络网警内网管理软件_电脑配置统计,系统日志,日志查询...

管理作用 管理者可以使用百络网警内网gua灵活查询的分类统计网内计算机的硬件和软件信息&#xff0c;为IT资产管理提供方便和决策支持。也可以让IT管理者从多个角度来了解网络内每台计算机的全面的日志信息&#xff0c;为故障排除和网络管理提供有力支持。 功能描述 1、资产管理…

不履行网络安全保护义务被处罚!合肥网警发布“净网2020”行动执法典型案例

今年以来&#xff0c;合肥网安部门坚决贯彻上级公安机关和市局党委的决策部署&#xff0c;深入推进“净网2020”专项工作&#xff0c;整顿网络秩序&#xff0c;治理网络乱象&#xff0c;查处了一批违反网络安全相关法律规定的案件&#xff0c;实现网络秩序持续向好&#xff0c;…

注意了!浏览色情网站被短信通知检讨?可能是诈骗!

来源 | 澎湃新闻、九派视频等 针对“网传有学生用校园网浏览色情网站被学校学工部短信通知深刻检讨”一事&#xff0c;9月23日&#xff0c;电子科技大学党委学生工作部相关工作人员告诉记者&#xff0c;已关注到网络上传播的图片&#xff0c;经查&#xff0c;该校学工部未发过此…

网警如何查虚拟服务器,网警查高防云服务器

网警查高防云服务器 内容精选 换一换 云服务器网络异常、防火墙未放行本地远程桌面端口、云服务器CPU负载过高等场景均可能导致云服务器无法正常登录。本节操作介绍无法登录Linux弹性云服务器的排查思路。当您的云服务器无法远程登录时&#xff0c;我们建议您首先检查是否可以通…

阿里巴巴和腾讯考虑相互开放!

本文转载自IT之家 IT之家 7 月 14 日 外媒今日表示&#xff0c;越来越大的监管压力可能会导致科技巨头的运营方式发生重大转变。 据华尔街日报&#xff0c;有消息人士透露称&#xff0c;阿里巴巴的初步举措可能包括将腾讯的微信支付引入淘宝和天猫&#xff1b;双方都在分别制…

修改注册表导致无法登录到你的账户

修改注册表失败导致无法登录到你的账号 电脑环境太乱了&#xff0c;完全重置了一次&#xff0c;进去发现微软很烂的设定&#xff0c;把邮箱前六位作为cmd下的默认用户名 尝试修改该值&#xff0c;regedit下修改 计算机\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\Curre…

最新开源多城市地方房产门户系统源码/ThinkPHP房产房市营销推广系统自适应移动端

最新开源多城市地方房产系统源码&#xff0c;房产房市营销推广系统去授权修复版自适应移动端 PHP版本号必须7.0之上才行&#xff0c;要不然会出错&#xff0c;这套源代码根据Thinkphp5.1开发的&#xff0c;功能齐全租房子&#xff0c;住宅小区&#xff0c;办公楼&#xff0c;二…

MiniGPT-4中文翻译

MiniGPT-4: 使用先进的大型语言模型增强视觉语言理解 作者为朱德尧、陈俊、沈晓倩、李翔和Mohamed Elhoseiny。*表示贡献相等。 所属机构为沙特阿拉伯国王科技大学。 在线演示 点击图像与MiniGPT-4聊天&#xff0c;了解有关您的图像的信息。 更多的例子可以在项目页面中找…

DevChat:将 GPT-4 无缝融入 VS Code,极致提升你的编程体验

文章目录 一、絮絮叨叨1.1 缘起1.2 嫌弃1.3 征服 二、认真聊聊2.1 老板给了少年一个任务2.2 少年祭出了 DevChat2.3 让 DevChat 帮着选 web 框架2.4 让 DevChat 帮着写代码2.5 让 DevChat 帮着写 Dockerfile2.6 让 DevChat 帮着封装 Helm Chart2.7 让 DevChat 帮着拉起 K8s 集群…

一个产品经理大骂程序员的帖子

大家好&#xff0c;我是校长。 今天看到一个帖子&#xff0c;是一个产品经理在吐槽程序员开发的问题。 大家可以看看这位产品经理骂的对吗&#xff1f; 当然了&#xff0c;在这类的帖子下&#xff0c;有我们程序员的各种反击和互怼&#xff0c;这很正常。 毕竟垃圾的产品经理和…

产品经理干久了,有哪些后遗症?

Hello&#xff0c;刀友们&#xff0c;大噶好&#xff01; 都说妇女能顶半边天&#xff0c;墨刀的一半功劳当然也少不了她们&#xff01; 墨墨姐专访了墨刀家的几位女神&#xff0c;身为女产品经理、女程序员&#xff0c;她们纷纷表示&#xff1a;这个职业干久了&#xff0c;都…