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

news2024/11/15 11:06:42

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

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

 @Override
    public 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.coloradmin.cn/o/510425.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

clickhouse linux 离线安装

1. 下载离线安装包&#xff0c;下四个包&#xff0c;版本号要一致, (在此下的是20.8.3.18-1.el7.x86_64版) clickhouse-server, clickhouse-client, clickhouse-common-static, clickhouse-server-common Altinity/clickhouse - Packages packagecloudBrowse pa…

人工智能基础部分15-自然语言处理中的数据处理上采样、下采样、负采样是什么?

大家好&#xff0c;我是微学AI&#xff0c;今天给大家介绍一下人工智能基础部分15-自然语言处理中的数据处理上采样、下采样、负采样是什么&#xff1f;在自然语言处理中&#xff0c;上采样、下采样、负采样都是用于处理数据不平衡问题的技术&#xff0c;目的是为了优化模型的训…

《记录》chariles配置

Charles配置 1、下载&#xff1a;官网下载-傻瓜式安装 2、windows配置解析pc端的https包 http包解析是配好的&#xff0c;需要自行配置https 2.1、下载证书 1、如图点击 之后下一步点完成就行。 2.2、代理设置 这里勾选其实勾不勾都行&#xff0c;默认不改也行。我是看了…

DC域控服务器与辅助DC域控服务器之间的数据同步以及创建域组织机构和域用户

本篇主要是处理DC域控服务器与辅助DC域控服务器之间的数据同步关系&#xff0c;DC域控服务器与辅助DC域控服务器的创建可以参考上篇文章 验证DC域控服务器与辅助DC域控服务器之间的数据同步关系&#xff0c;分别在辅助DC域控服务器DC上面新建一个用户&#xff0c;看看再对应的…

一名【合格】前端工程师的自检清单

1.JavaScript规定了几种语言类型&#xff1f; 基本数据类型&#xff1a;number、string、boolean、null、undefined、symbol(es6) 对象引用类型&#xff1a;Array、Function、Object、RegExp、Error、Date 2.JavaScript对象的底层数据结构是什么&#xff1f; JavaScript 对象…

甄云科技对话格瑞德,探讨高复杂度采购事业的数“智”解决之道

在由甄云科技主办的客户高层访谈节目“甄知访谈”中&#xff0c;本期我们走进山东格瑞德集团&#xff0c;一起来分享格瑞德的采购数字化转型之路。由甄云科技总裁姚一鸣对话格瑞德集团有限公司供应链总经理徐涵先生。 山东格瑞德集团成立于 1993 年&#xff0c;是一家围绕人工…

[pgrx开发postgresql数据库扩展]7.返回序列的函数编写(2)表序列

前文再续&#xff0c;书接上一回。 上一节我们简单说了利用SetOfIterator返回一个srf&#xff08;Set Returning Functions&#xff09;&#xff0c;但是很多情况下&#xff0c;一个单值序列并不能很好的满足我们的需求&#xff0c;所以今天我们来说另外一个作用更广泛的srf&a…

您有一条群邀请消息:施耐德电气“绿色智能制造创赢计划”第四季正式启动!

4月26日&#xff0c;由工业和信息化部国际经济技术合作中心与施耐德电气共同主办的“2023绿色智能制造创赢计划”第四季正式启动 。 这一计划为拥有**技术专长与发展潜力的中小企业提供联合共创平台&#xff0c;帮助企业加速突破工业场景中的关键痛点&#xff0c;孵化和落地更…

GDB调试-从安装到使用

1、GDB简介 gdb 工具是 GNU 项目调试器&#xff0c;基于命令行。和其他的调试器一样&#xff0c;我们可以使用 gdb 来一行行的运行程序、单步执行、跳入/跳出函数、设置断点、查看变量等等&#xff0c;它是 UNIX/LINUX 操作系统下强大的程序调试工具。对于一般的Linux桌面系统(…

Nginx:worker_processes、worker_connections设置

转自&#xff1a;Nginx&#xff1a;worker_processes、worker_connections设置_worker_connections设置多少_it_zhenxiaobai的博客-CSDN博客 worker_processes与worker_connections 设置好合适大小&#xff0c;可以提升 nginx 处理性能&#xff0c;非常重要。 原作者的话&…

【PSO-LSTM】基于PSO优化LSTM网络的电力负荷预测(Python代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

eSIM证书要求-涉及规范SGP.22-SGP.26-2

subjectPublicKeyInfo 证书链中所有证书的subjectPublicKeyInfo中的OID都是一样的 CRL Distribution Point 证书吊销列表分发点 (CRL Distribution Point &#xff0c;简称 CDP) 是含在数字证书中的一个可以共各种应用软件自动下载的最新的 CRL 的位置信息。一个 CDP 通常出现…

egg.js + mysql + windows 踩坑全纪录

资料&#xff1a; egg.js文档&#xff08;https://www.eggjs.org/zh-CN/intro/quickstart&#xff09; 背景&#xff1a;前面的都很简单&#xff0c;按照官方文档配置即可&#xff0c;全部调通以后&#xff0c;开始接触数据库mysql 因为米有后台开发背景&#xff0c;所以需要从…

从IDC数据库安全报告,看OceanBase安全能力

欢迎访问 OceanBase 官网获取更多信息&#xff1a;https://www.oceanbase.com/ 作为数据的承载工具&#xff0c;数据库自身安全能力对于数据安全至关重要。数据库软件诞生至今&#xff0c;经过了几十年的发展和演进&#xff0c;已经成为 IT 系统中不可或缺的关键技术。但是随着…

MySQL原理(三):索引

前言 上一篇介绍了 MySQL 的逻辑架构和执行过程&#xff0c;这一篇将介绍索引相关的内容。 索引是用额外的数据结构&#xff0c;来实现快速检索目标数据的。就像字典当中的目录一样&#xff0c;用额外的空间来存储部分内容&#xff0c;从而加快检索速度。 MySQL 的逻辑架构分…

Python——PyQt5在PyCharm的配置与应用(保姆级教程)

目录 一、安装pycharm与python版本 二、升级pip与换源&#xff0c;安装PyQt5、PyQt5-tool 三、添加环境变量 四、在pycharm的外部工具里添加3个工具 4.1、添加三个插件&#xff08;重点&#xff09; 五、如何使用QtDesigner 六、如何使用pyuic5 一、安装pycharm与python版…

C语言——扫雷小游戏(递归展开版)

哈喽&#xff0c;大家好&#xff0c;上次我们已经学习了三子棋小游戏&#xff0c;今天我们来学习扫雷小游戏了。 目录 1.游戏介绍 2.函数部分 2.1菜单 2.2game()函数 2.3mian()函数 2.4初始化棋盘 2.5打印棋盘 2.6布置雷 2.7排查雷 2.8统计雷 2.9递归,展开一片区域 …

眼球追踪、HDR、VST,从代码挖掘Valve下一代VR头显

擅长爆料、挖掘线索的Brad Lynch&#xff0c;此前发布了Quest Pro等设备的线索文章引发关注。​近期&#xff0c;又公布一系列与“Valve Deckard”VR头显相关消息&#xff0c;比如支持眼球追踪、HDR、VST透视、Wi-Fi网络等等。在SteamVR 1.26.1测试版更新、Steam用户端、Gamesc…

lazada、shopee转化率低怎么办?做好这几点,让你的店铺转化率提升

如若lazada, shopee如果转化率低&#xff0c;商家需要做好以下几个方面&#xff0c;通过以下几点来提高。毕竟只有流量没有转化率&#xff0c;店铺管理不好。 1、产品类别的选择 一个好的类别本身就是一个很好的排水渠道&#xff0c;可以给我们带来大量的流量&#xff0c;高流…

数据结构与算法基础(王卓)(38):排序、全部PPT、笔记整理

首先&#xff0c;庆祝本系列完结撒花&#xff01; 对了&#xff0c;后续应该会把王卓老师所有的PPT附带笔记全部打包上传百度云 回头我把链接贴出来&#xff0c;感兴趣的朋友可以Mark一下&#xff0c;希望可以帮助到大家 如果有什么写的不对的地方&#xff0c;先给大家说声抱…