bodyHealthy 2023-05-19 05:16 采纳率: 80%
浏览 32
已结题

关于js、nodejs处理pptx的问题

对于一个pptx文件,能不能用node提取出每一张幻灯片,然后生成图片,把地址传给前端,然后前端以一张一张图片的形式来展现pptx文件?
或者只有能在前端网页里面以图片或者画布的形式把pptx中的每一个幻灯片依次展示出来,有没有什么办法,有没有什么库可以使用?

  • 写回答

1条回答 默认 最新

  • 掩月天权 2023-05-19 05:43
    关注

    用于处理pptx文件的流行Node.js库是pptxgenjs。

    示例代码:

    const PptxGenJS = require('pptxgenjs');
    const fs = require('fs');
    
    // 创建一个新的pptx文档对象
    const pptx = new PptxGenJS();
    
    // 向pptx文档中添加多个幻灯片
    pptx.addSlide();
    pptx.addSlide();
    pptx.addSlide();
    
    // 将幻灯片转换为Base64编码的PNG图像
    const images = [];
    for (let i = 1; i <= pptx.slides.length; i++) {
      const slide = pptx.slides[i - 1];
      images.push({
        name: `Slide${i}.png`,
        data: slide.getBlob().toString('base64')
      });
    }
    
    // 将图像保存到磁盘或通过HTTP发送给前端
    images.forEach(image => {
      fs.writeFileSync(image.name, Buffer.from(image.data, 'base64'));
    });
    

    在上面的示例代码中,我们首先使用pptxgenjs创建了一个新的pptx文档对象,并向该文档添加了三个幻灯片。然后,我们遍历每个幻灯片并使用getBlob()方法将其转换为PNG图像的Buffer对象。最后,我们将这些图像保存到磁盘或通过HTTP发送给前端。

    评论
    bodyHealthy 2023-05-19 06:38

    怎么读取本地或网络的pptx来用?pptxgen好像只有创建和导出的,这里用pptxgen再创建新的ppt,不理解是要怎么实现

    回复
    掩月天权 回复 bodyHealthy 2023-05-19 06:44

    直接读取本地的就可以了啊,不是有读取方法吗?

    const fs = require('fs');
    const pptxgen = require('pptxgenjs');
    
    // 读取 PPTX 文件的二进制数据
    const pptxData = fs.readFileSync('./example.pptx');
    
    // 创建 PPTX 实例并加载二进制数据
    const pptx = new pptxgen();
    pptx.load(pptxData);
    
    // 将每一页转换为图片
    const imageBuffers = pptx.slidesToImage({ quality: 100 });
    
    // 返回第一张图片作为响应
    res.writeHead(200, { 'Content-Type': 'image/png' });
    res.end(imageBuffers[0]);
    
    

    回复
    bodyHealthy 回复 掩月天权 2023-05-19 06:59

    噢,懂了,谢谢大佬🤗🤗,等我晚上回去再实践一下

    回复
    展开全部5条评论
    编辑
    预览

    报告相同问题?

    问题事件

    • 已结题 (查看结题原因) 5月25日
    • 创建了问题 5月19日
    手机看
    程序员都在用的中文IT技术交流社区

    程序员都在用的中文IT技术交流社区

    专业的中文 IT 技术社区,与千万技术人共成长

    专业的中文 IT 技术社区,与千万技术人共成长

    关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

    关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

    客服 返回
    顶部