0

0

使用 JavaScript 将 HTML 表格追加到现有 Excel 文件

聖光之護

聖光之護

发布时间:2025-08-17 19:48:13

|

922人浏览过

|

来源于php中文网

原创

使用 javascript 将 html 表格追加到现有 excel 文件

本文介绍了如何使用 JavaScript 和 SheetJS 社区版库,将 HTML 表格数据追加到现有的 Excel 文件中,并在每次运行时创建一个新的工作表。该方案通过读取 HTML 表格数据、下载原始 Excel 文件、将新工作表追加到原始文件,并启动新文件的下载来实现。

方案概述

本教程将引导你完成使用 JavaScript 将 HTML 表格数据追加到现有 Excel 文件的过程。我们将使用 SheetJS 库来实现此目的。SheetJS 是一个强大的 JavaScript 库,用于读取和写入各种电子表格格式。

准备工作

在开始之前,请确保你已具备以下条件:

  • 一个包含 HTML 表格的网页。
  • 一个现有的 Excel 文件。
  • 在你的项目中引入 SheetJS 库。 你可以通过以下 CDN 链接引入:

实现步骤

以下是将 HTML 表格追加到现有 Excel 文件的步骤:

立即学习Java免费学习笔记(深入)”;

  1. 获取 HTML 表格数据:

    首先,我们需要从 HTML 表格中提取数据。我们可以使用 XLSX.utils.table_to_book() 方法将 HTML 表格转换为 SheetJS 工作簿对象。

    var data_to_append = XLSX.utils.table_to_book(document.getElementById("test_table"));

    其中,test_table 是你的 HTML 表格的 ID。

  2. 获取工作表:

    从工作簿对象中获取要追加的工作表。通常,HTML 表格转换后的工作簿会包含一个名为 "Sheet1" 的工作表。

    科威旅游管理系统
    科威旅游管理系统

    该软件是以php+MySQL进行开发的旅游管理网站系统。系统前端采用可视化布局,能自动适应不同尺寸屏幕,一起建站,不同设备使用,免去兼容性烦恼。系统提供列表、表格、地图三种列表显示方式,让用户以最快的速度找到所需行程,大幅提高效率。系统可设置推荐、优惠行程,可将相应行程高亮显示,对重点行程有效推广,可实现网站盈利。系统支持中文、英文,您还可以在后台添加新的语言,关键字单独列出,在后台即可快速翻译。

    下载
    const newSheet = data_to_append.Sheets["Sheet1"];
  3. 下载原始 Excel 文件:

    使用 fetch API 下载原始 Excel 文件。你需要提供 Excel 文件的 URL。

    const url = "https://www.lucasroquilly.com/stack_overflow_samples/workbook.xls";
    const data = await (await fetch(url)).arrayBuffer();
  4. 创建工作簿:

    使用 XLSX.read() 方法从原始 Excel 文件数据创建 SheetJS 工作簿对象。

    const workbook = XLSX.read(data);
  5. 追加工作表:

    使用 XLSX.utils.book_append_sheet() 方法将新的工作表追加到原始工作簿。你需要提供工作簿对象、要追加的工作表和新工作表的名称。

    XLSX.utils.book_append_sheet(workbook, newSheet, "Appended Sheet", true);
  6. 启动下载:

    使用 XLSX.writeFile() 方法启动新 Excel 文件的下载。你需要提供工作簿对象和文件名。

    XLSX.writeFile(workbook, 'workbook.xls');

完整代码示例

(async() => {
  // GET DATA TO APPEND FROM HTML TABLE
  var data_to_append = XLSX.utils.table_to_book(document.getElementById("test_table"));
  // GET SHEET "Sheet1" FROM DATA TO APPEND
  const newSheet = data_to_append.Sheets["Sheet1"];
  // GET ORIGINAL XLS FILE
  const url = "https://www.lucasroquilly.com/stack_overflow_samples/workbook.xls";
  const data = await (await fetch(url)).arrayBuffer();
  /* CREATE WORKBOOK FROM ORIGINAL XLS FILE DATA */
  const workbook = XLSX.read(data);
  // APPEND SHEET TO WORKBOOK UNDER NAME "Appended Sheet"
  XLSX.utils.book_append_sheet(workbook, newSheet, "Appended Sheet", true);
  //ATTEMPT TO LAUNCH DOWNLOAD OF FILE
  XLSX.writeFile(workbook, 'workbook.xls');
})();

HTML 表格示例

Header 1Header 2Header 3Header 4Header 5
NEW Row:1 Cell:1NEW Row:1 Cell:2NEW Row:1 Cell:3NEW Row:1 Cell:4Row:1 Cell:5
NEW Row:2 Cell:1NEW Row:2 Cell:2NEW Row:2 Cell:3NEW Row:2 Cell:4NEW Row:2 Cell:5

CSS 样式示例

.tftable {font-size:12px;color:#333333;width:100%;border-width: 1px;border-color: #729ea5;border-collapse: collapse;}
.tftable th {font-size:12px;background-color:#acc8cc;border-width: 1px;padding: 8px;border-style: solid;border-color: #729ea5;text-align:left;}
.tftable tr {background-color:#d4e3e5;}
.tftable td {font-size:12px;border-width: 1px;padding: 8px;border-style: solid;border-color: #729ea5;}
.tftable tr:hover {background-color:#ffffff;}

注意事项

  • 此代码需要在支持 fetch API 的环境中运行。
  • 由于安全限制,某些浏览器可能不允许直接下载文件。你可能需要在服务器端处理文件下载。
  • 确保提供的 Excel 文件 URL 是正确的,并且可以访问。
  • SheetJS 社区版在处理大型 Excel 文件时可能会遇到性能问题。如果需要处理大型文件,请考虑使用 SheetJS 专业版。

总结

本教程介绍了如何使用 JavaScript 和 SheetJS 库将 HTML 表格数据追加到现有 Excel 文件。通过这些步骤,你可以轻松地将网页上的数据导出到 Excel 文件中,并实现数据的动态更新和管理。 通过修改代码,你可以轻松地适应不同的场景和需求。例如,你可以根据需要自定义工作表的名称,或者将数据追加到特定的工作表中。

相关文章

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
excel对比两列数据异同
excel对比两列数据异同

Excel作为数据的小型载体,在日常工作中经常会遇到需要核对两列数据的情况,本专题为大家提供excel对比两列数据异同相关的文章,大家可以免费体验。

1399

2023.07.25

excel重复项筛选标色
excel重复项筛选标色

excel的重复项筛选标色功能使我们能够快速找到和处理数据中的重复值。本专题为大家提供excel重复项筛选标色的相关的文章、下载、课程内容,供大家免费下载体验。

409

2023.07.31

excel复制表格怎么复制出来和原来一样大
excel复制表格怎么复制出来和原来一样大

本专题为大家带来excel复制表格怎么复制出来和原来一样大相关文章,帮助大家解决问题。

562

2023.08.02

excel表格斜线一分为二
excel表格斜线一分为二

在Excel表格中,我们可以使用斜线将单元格一分为二。本专题为大家带来excel表格斜线一分为二怎么弄的相关文章,希望可以帮到大家。

1243

2023.08.02

excel斜线表头一分为二
excel斜线表头一分为二

excel斜线表头一分为二的方法有使用合并单元格功能方法、使用文本框功能方法、使用自定义格式方法。本专题为大家提供excel斜线表头一分为二相关的各种文章、以及下载和课程。

368

2023.08.02

绝对引用的输入方法
绝对引用的输入方法

绝对引用允许在公式中引用一个固定的单元格,而不会随着公式的复制和粘贴而改变引用的单元格。本专题为大家提供绝对引用相关内容的文章,大家可以免费体验。

4526

2023.08.09

java导出excel
java导出excel

在Java中,我们可以使用Apache POI库来导出Excel文件。本专题提供java导出excel的相关文章,大家可以免费体验。

408

2023.08.18

excel输入值非法
excel输入值非法

在Excel中,当输入的数值非法时,有以下多种处理方法。本专题为大家提供excel输入值非法的相关文章,大家可以免费体验。

1019

2023.08.18

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

CSS教程
CSS教程

共754课时 | 24.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号