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

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

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

方案概述

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

准备工作

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

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


实现步骤

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

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

获取 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。

获取工作表:

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

const newSheet = data_to_append.Sheets["Sheet1"];

下载原始 Excel 文件:

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

const url = "https://www.lucasroquilly.com/stack_overflow_samples/workbook.xls";const data = await (await fetch(url)).arrayBuffer();

创建工作簿:

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

const workbook = XLSX.read(data);

追加工作表:

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

XLSX.utils.book_append_sheet(workbook, newSheet, "Appended Sheet", true);

启动下载:

使用 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 文件中,并实现数据的动态更新和管理。 通过修改代码,你可以轻松地适应不同的场景和需求。例如,你可以根据需要自定义工作表的名称,或者将数据追加到特定的工作表中。

以上就是使用 JavaScript 将 HTML 表格追加到现有 Excel 文件的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1572460.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月22日 14:38:13
下一篇 2025年12月22日 14:38:28

相关推荐

  • HTML如何设置字体大小?font size属性的作用是什么?

    使用CSS的font-size属性设置字体大小,推荐通过外部样式表结合rem、em、px等单位实现灵活、可维护的响应式设计,避免使用已废弃的HTML font标签,以确保跨设备一致性和可访问性。 在HTML中设置字体大小,现在主要通过CSS(层叠样式表)来完成,而不是直接在HTML标签里。HTML本…

    2025年12月22日
    000
  • 表单中的meter标签有什么用?如何显示度量值?

    标签的主要作用是显示已知范围内的度量值,用于展示静态的、有上下限的数值状态,如硬盘使用率或考试成绩占比,而非任务进度(那是 的用途);它通过 value、min 和 max 属性定义当前值和范围,并可结合 low、high 和 optimum 属性提供语义上下文,帮助浏览器和辅助技术判断数值所处区间…

    2025年12月22日
    000
  • 优化Angular Material Tooltip长内容显示与定位策略

    针对Angular Material中当Tooltip内容过长时,即使设置为底部定位,仍可能出现向右偏移的问题,本文将探讨其原因,并提供通过合理配置matTooltipPosition和利用matTooltipClass应用自定义CSS来控制Tooltip宽度及优化其在不同场景下显示位置的实用策略,…

    2025年12月22日
    000
  • HTML如何引入JavaScript?script标签的用法是什么?

    推荐将JavaScript脚本放在body末尾或使用defer属性,因为能避免阻塞页面渲染,提升加载速度和用户体验。 将JavaScript引入HTML主要通过 标签实现,它允许你直接在HTML文档中嵌入JS代码,或者链接到外部的 .js 文件。这是前端交互的基石,也是让静态页面“活”起来的关键。 …

    2025年12月22日
    000
  • HTML如何设置时间显示样式?time-display伪类的用法是什么?

    答案:CSS通过选择器和属性控制时间显示样式,无法直接用伪类time-display。具体做法是为时间元素(如、)设置类名或ID,再用CSS定义字体、颜色、间距等外观;若需格式化时间内容,则依赖JavaScript处理,HTML结构可嵌套span实现分部分样式控制;响应式设计需结合rem、媒体查询、…

    2025年12月22日
    000
  • 为 React 中的文本选择添加超链接的正确方法

    在 React WYSIWYG 编辑器中为选定文本添加超链接时遇到的问题。核心在于如何在修改选区背景色的同时,保持对选区范围的引用,以便后续插入超链接。通过分析问题原因,提供了一种基于查找新 Span 文本节点的方法,确保超链接功能的顺利实现。 在构建富文本编辑器时,为用户提供超链接功能是一项常见的…

    2025年12月22日
    000
  • React 中为选中文本添加超链接的正确方法

    第一段引用上面的摘要: 本文旨在解决 React 应用中为用户选中的文本动态添加超链接的问题。核心思路是在用户选中文本后,通过 window.getSelection() 获取选区,并利用 document.execCommand() 实现超链接的插入。重点在于正确处理选区范围,避免在修改文本样式后…

    2025年12月22日
    000
  • React 中为文本选择添加超链接的实现方法

    React 中为文本选择添加超链接的实现方法 在构建富文本编辑器(WYSIWYG)时,为选中文本添加超链接是一个常见需求。本文将介绍一种在 React 中实现此功能的方法,并重点解决在添加背景颜色后 Range 对象丢失的问题。 首先,我们需要监听用户点击超链接按钮的事件。当用户点击按钮时,我们希望…

    2025年12月22日
    000
  • React 中为文本选择添加超链接的正确方法

    第一段引用上面的摘要: 本文介绍了在 React WYSIWYG 编辑器中为选定文本添加超链接的正确方法。核心思路是,在添加背景色后,由于会生成 span 标签,需要基于新的 span 文本节点重新创建 range 对象,并提供了一个辅助函数来查找这个文本节点。通过这种方式,可以解决 range 对…

    2025年12月22日
    000
  • 如何在 DataTables 中固定首行置顶

    本文档介绍了如何在 DataTables 表格中实现首行固定置顶的效果,即使在进行排序操作时,首行也能始终保持在表格顶部。通过修改 HTML结构,将需要固定的行放置在 标签内,可以轻松实现这一功能,同时保持表格的排序和其他 DataTables 功能的正常运作。 使用 标签固定 DataTables…

    2025年12月22日
    000
  • HTML如何实现范围滑块?input type=”range”怎么用?

    input type=”range” 是 HTML 中创建范围滑块的基本方式,通过 min、max、value 和 step 属性定义滑块的最小值、最大值、当前值和步长。要实现实时数值显示,需结合 JavaScript 监听 input 事件,利用事件实时更新页面中的 spa…

    2025年12月22日
    000
  • HTML表单如何实现假名化?怎样替换可识别信息?

    答案:HTML表单假名化通过将姓名、邮箱、电话等直接标识符替换为假名标识符,在保护用户隐私的同时保留数据可分析性。主要实现策略包括客户端预处理和服务器端处理,其中服务器端处理更安全,推荐在数据提交后由后端对敏感信息进行哈希、令牌化等操作。假名化不同于匿名化,其可逆特性允许在受控条件下重新识别个体,平…

    2025年12月22日
    000
  • HTML如何设置div容器?div标签的作用是什么?

    div容器的设置主要通过css实现,其核心作用是内容组织和布局;1. 使用html的 标签创建容器;2. 通过内联、内部或外部css设置样式,常用属性包括width、height、background-color、border、padding、margin等;3. 利用css grid布局可实现二维…

    2025年12月22日
    000
  • 使用 Path2D 实现拖拽元素到网格的吸附效果

    本文将介绍如何使用 JavaScript 和 HTML5 Canvas 实现一个拖拽元素到网格并自动吸附到网格中心的功能。我们将使用 Path2D 对象来定义网格,并利用其 isPointInPath() 方法来检测拖拽元素是否位于某个网格内。通过为 Path2D 对象添加自定义数据,可以方便地实现…

    2025年12月22日
    000
  • 实现拖拽元素到 Canvas 网格并自动吸附到中心点的教程

    本教程旨在帮助开发者实现在 Canvas 画布上拖拽一个元素,并在鼠标释放时,使该元素自动吸附到最近的网格中心点的功能。我们将通过为 Path2D 对象添加自定义数据,并在鼠标抬起事件中计算元素的新位置来实现这一效果。通过学习本教程,你将掌握 Canvas 元素拖拽和吸附的核心技术,并能将其应用到更…

    2025年12月22日
    000
  • 实现拖拽元素在 Canvas 网格中自动吸附

    本文旨在解决在 HTML5 Canvas 中实现拖拽元素到指定网格并自动吸附的问题。通过为 Path2D 对象附加自定义数据,并在鼠标释放时根据鼠标位置判断目标网格,最终实现元素自动吸附到网格中心的功能。文章将提供详细的代码示例,帮助开发者理解和应用该技术。 实现步骤 创建 Canvas 网格: 首…

    好文分享 2025年12月22日
    000
  • 使用 Owl Carousel 实现封面效果:解决 cover 属性失效问题

    本文旨在解决在使用 Owl Carousel 2.3.4 时,CSS 中的 cover 属性失效,导致图片无法正确显示为封面效果的问题。通过配置 Owl Carousel 的 items 属性,可以强制 Carousel 每次只显示一个项目,从而实现预期的封面效果。本文将提供详细的配置方法和示例代码…

    2025年12月22日 好文分享
    000
  • HTML表单如何添加范围滑块?range类型的input怎么用?

    range滑块常用属性包括min、max、value、step、list、name和id,其中min和max定义取值范围,value设置初始值,step控制步长精度,list关联datalist显示刻度标记,name用于表单提交时的数据识别,id用于JavaScript和CSS定位及无障碍访问。实时…

    2025年12月22日
    000
  • HTML如何设置表单滑块?input type=”range”怎么用?

    使用可创建HTML滑块,通过min、max、value和step属性定义范围、默认值和步长,结合JavaScript监听input事件实现实时数值显示,提升用户体验;step值影响精度与操作便捷性,需根据场景权衡;默认样式跨浏览器不一致,需用CSS伪元素如::-webkit-slider-thumb…

    2025年12月22日
    000
  • 解决 Angular Material Tooltip 内容过长时位置偏移问题

    本文旨在解决 Angular Material Tooltip 在其关联内容过长时,工具提示(tooltip)显示位置异常偏右的问题。核心策略是利用 matTooltipPosition 属性将工具提示的显示方向调整至元素下方,从而有效避免水平方向上的位置偏移,并提供相应的代码示例及其他排查建议。 …

    2025年12月22日
    000

发表回复

登录后才能评论
关注微信