【GPT4结对编程】word文档导出功能&GPT4来实现

文章讲述了在产品新增导出Word文档需求背景下,对Golang和Java相关开源框架的调研过程。作者尝试了unioffice和docx等工具,但因限制而转向ApachePOI。ApachePOI提供了更强大的功能,包括模板替换和图片处理,文中给出了使用ApachePOI创建Word文档的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

需求背景

最近产品增加了一个导出word文档的需求,之前有导出过pdf格式、excel格式、csv格式,但还没导出过word文档。

开源框架调研

我们的后端服务主要是用golang,因此首先想到的是golang相关的开源工具,找到2个。

unioffice

这个是工具比较强大,支持微软办公软件的3件套,word、excel 和 ppt,但要使用的话需要商业授权,因此只能暂时放弃。

github.com/nguyenthenguyen/docx

另外找到的就是这个工具,个人开发着实现的,不过功能比较弱,有很多局限性:

  1. 只能基于word文档模版替换里面的内容;
  2. 图片的插入数量必须和模版里面的图片数量一致;
  3. 图片格式必须与模版里面的一致(png格式的图片不能使用jpg替换);
  4. 替换模版里面的标识符比较容易出错,似乎只要报错一下word文本里面的格式就替换不了(可能是我的问题);
  5. 不支持列表输出文档。

上面2个不满足需求,继续调研了下java相关的工具。

github.com/Sayi/poi-tl

功能也是支持word模版替换,比上面的golang工具稍微强大点:
1、支持list输出文档;
2、图片替换模版里面的文字,不限制图片格式,但是输出的图片格式有问题,会导致超过文字高度的图片被遮挡。

github.com/apache/poi

上面的poi-tl 的底层库实际上就是apache poi,调研apache poi发现他的功能非常强大,对微软的办公软件支持比较全面,文档也比较全,使用可以参考:https://www.tutorialspoint.com/apache_poi_word/apache_poi_word_quick_guide.htm

demo

了解这个信息之后,我直接让GPT4给我写demo,下面是我们的对话:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

最终版本

import org.apache.poi.util.Units;
import org.apache.poi.xwpf.usermodel.*;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.imageio.ImageIO;
import javax.servlet.http.HttpServletResponse;
import java.awt.image.BufferedImage;
import java.io.InputStream;
import java.net.URL;
import java.net.URLConnection;
import java.util.Arrays;
import java.util.List;

@RestController
public class WordTemplateController {

    @GetMapping(value = "/download", produces = MediaType.APPLICATION_OCTET_STREAM_VALUE)
    public void download(HttpServletResponse response) throws Exception {
        // 创建一个新的文档
        XWPFDocument doc = new XWPFDocument();

        // 添加文本
        XWPFParagraph p1 = doc.createParagraph();
        XWPFRun r1 = p1.createRun();
        r1.setText("这是一段文本。");
        r1.setFontSize(14);  // 设置字体大小
        r1.setBold(true);  // 设置为加粗

        // 添加换行
        r1.addBreak();

        // 添加另一段文本
        XWPFRun r2 = p1.createRun();
        r2.setText("这是另一段文本。");
        r2.setFontSize(12);  // 设置字体大小
        r2.setBold(false);  // 设置为非加粗

        // 图片URL列表
        List<String> imgUrls = Arrays.asList("http://example.com/image1.jpg", "http://example.com/image2.jpg");

        for (String imgUrl : imgUrls) {
            URL url = new URL(imgUrl);
            URLConnection connection = url.openConnection();
            InputStream is = connection.getInputStream();

            // 读取图片并获取其宽度和高度
            BufferedImage img = ImageIO.read(is);
            int widthPx = img.getWidth();
            int heightPx = img.getHeight();

            // 按照需要的比例调整宽度和高度
            double scale = 0.5;  // 缩小到原来的50%
            int width = Units.toEMU(widthPx * scale);
            int height = Units.toEMU(heightPx * scale);

            // 重新打开输入流,因为之前的已经被读取过了
            is = url.openStream();

            XWPFParagraph p = doc.createParagraph();
            XWPFRun r = p.createRun();

            int format = XWPFDocument.PICTURE_TYPE_JPEG;

            r.addPicture(is, format, imgUrl, width, height);
        }

        // 设置响应头
        response.setHeader("Content-Disposition", "attachment; filename=output.docx");
        response.setContentType("application/vnd.openxmlformats-officedocument.wordprocessingml.document");

        // 将文档写入到

总结

从对话可以看的出来,GPT4强大的代码能力和理解能力,生成的代码都是可以直接运行的,每一次我需要对程序的修改,都能按照我想要的方式完成,我不需要去看POI的官网文档,不需要理解api,直接告诉GPT4我需要什么就可以了,真的非常逆天,我花了那么多时间调研来调研去,为何不一开始就问GPT4呢,可能我想体现自己的价值吧。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

竹二木

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值