_fs.readFileSync is not a function

news2025/1/20 5:59:27

背景

项目需要通过读取本地一个 xlsx 的可配置文件,并生成 json 格式的文件。

查找资料发现 js 的 xlsx 库可以对 xlsx 文件进行读写和格式转换的操作,也看到了几篇xlsx结合elementui处理文件的博文,于是写下了如下代码,结果报错 _fs.readFileSync is not a function

import xlsx from "xlsx"

const parseExcel = () => {
	const workBook = xlsx.readFile("template.xlsx",{});
	console.log(workBook);
}

原因

在浏览器环境中,由于安全考虑,前端JavaScript代码不能直接读取本地文件,即使是访问本地计算机上的文件系统也不行。这是因为浏览器的安全机制限制了跨域访问和访问本地文件,从而避免恶意脚本获取用户的敏感数据或修改本地文件系统。

但是,在特定情况下,可以通过某些技术手段实现前端读取本地文件的功能。例如,可以借助HTML5标准中的File API,允许用户通过文件选择框选择本地文件,并将其内容传递给JavaScript代码进行处理。此外,也可以使用一些WebView、Electron等开发框架,通过特定设置来实现前端读取本地文件的需求。

也就是说,虽然 xlsx 读取文件的函数有两个,但是这两个函数并不是都能在 client 端用的。

  • xlsx.read(data,read_opts) 这个函数是可以在client端调用的,可以配合一些上传文件的组件来用,通过这些上传文件的组件取到文件数据,作为data传进去就可以在前端解析文件数据了。
  • xlsx.readFile(Filename,read_opts) 这个函数只能在 nodejs 中使用,跟 fs 差不多,是没法直接在 client 端使用的。

在这里插入图片描述
(图片来自:js-xlsx 使用总结 实现前端解析excel,关于xlsx库的一些详细参数也可以参考这篇文章)

解决办法

  1. 通过前端上传文件的方式,获取文件数据,使用 xlsx.read(data,read_opts) 获取文件数据。
  2. xlsx.readFile(Filename,read_opts) 函数在 nodejs 中读取文件。这种方式要把
import xlsx from "xlsx";

改成

const xlsx = require("xlsx");

我使用的nodejs的方式,具体步骤记录在:nodejs处理xlsx文件生成json文件

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/532213.html

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

相关文章

Servlet技术及代码实现

Servlet概念 Servlet是JavaEE规范之一,规范指的就是接口。Servlet是JavaWeb三大组件之一,三大组件分别是:Servlet程序、Filter过滤器、Listener监听器。Servlet是运行在服务器上的一个java小程序,它可以接收客户端发送过来的请求&#xff0c…

5个设计师都在用的在线网页设计编辑器!

在当今的设计领域,选择一款适合的在线网页设计编辑器对于产设研团队来说至关重要。有许多选择可供考虑,其中包括即时设计、Axure RP、Adobe Illustrator、Sketch 和 Figma 等工具。在这些选择中,即时设计是一款备受推荐的在线网页设计编辑器。…

搭建免费的文件自动同步服务器,无公网IP外网远程访问【Syncthing私人云盘】

文章目录 1. 前言2. Syncthing网站搭建2.1 Syncthing下载和安装2.2 Syncthing网页测试2.3 注册安装cpolar内网穿透 3. 本地网页发布3.1 Cpolar云端设置3.2 Cpolar本地设置 4. 公网访问测试5. 结语 转发自CSDN远程穿透的文章:Syncthing文件同步 - 免费搭建开源的文件…

计算机网络 | 基于UDP的C/S模型代码实现

欢迎关注博主 Mindtechnist 或加入【Linux C/C/Python社区】一起学习和分享Linux、C、C、Python、Matlab,机器人运动控制、多机器人协作,智能优化算法,滤波估计、多传感器信息融合,机器学习,人工智能等相关领域的知识和…

高端NEV社媒阵地火热加温,蔚来最来“电”,极氪最“美丽”

Social Power 核心解读 汽车高端NEV SMI本月新势力领衔 极氪、凯迪拉克美誉度拉满 社媒阵地,已开局,战不休。 本月由数说故事行业首创的SMI社媒心智品牌榜单中,蔚来最来“电”荣登榜首,理想紧随其后,智己已是三哥。 …

BFT 最前线 | 互联网惊现 AI 鬼城,中国电信天翼云将发布预训练大模型,周鸿祎谈“万模大战”

文 | BFT机器人 01 网易CEO 丁磊:人工智能价值已被引导到生产第一线 网易数帆推出 CodeWave 智能开发平台。据了解,网易数帆结合自身产品的定位,面向智能编程垂直领域推出大模型,并接入到智能开发平台中。网易 CEO 丁磊表示&…

国内AI大模型汇总(附申请网址),建议收藏!

文章目录 前言1. AI文本工具站效率工具自媒体创作工具代码工具 2.道和顺ChatIC3.星期五4.文心一言5.讯飞星火认知大模型6.通义千问7.商汤-日日新8.Moss9.ChatGLM10. 360智脑写在最后 前言 随着ChatGPT迅速走红,国内各大企业纷纷发力认知大模型领域。经过一段时间的酝酿&#x…

【youcans动手学模型】LeNet 模型 MNIST 手写数字识别

欢迎关注『youcans动手学模型』系列 本专栏内容和资源同步到 GitHub/youcans 【youcans动手学模型】LeNet 模型 MNIST 手写数字识别 1. LeNet5 卷积神经网络模型1.1 论文简介1.2 卷积神经网络1.3 LeNet5 网络1.4 模型的运行结果 2. 在 PyTorch 中定义 LeNet5 模型类2.1 使用 nn…

如何设计一个合格的高并发秒杀系统

一、前言 在前面的文章中,详细阐述了建设秒杀系统的目标与存在的挑战,并且简单罗列了如何应对这些挑战的方式。本章,就详细阐述对秒杀系统存在挑战的应对之道,最终构建出兼具高并发、高性能和高可用的秒杀系统。心中不仅了解建设…

中原银行:数据资产管理与运营实践

关 注gzh"大数据食铁兽",了解更多的银行大数据案例 案例简介 中原银行整合内外部数据资源,以业务价值为导向,创新面向敏捷组织的AgileData数据治理方法论,依托工具化、自动化、智能化的治理手段与运营方式,…

CSS--移动web基础

01-移动 Web 基础 谷歌模拟器 模拟移动设备,方便查看页面效果 屏幕分辨率 分类: 物理分辨率:硬件分辨率(出厂设置)逻辑分辨率:软件 / 驱动设置 结论:制作网页参考 逻辑分辨率 视口 作用&a…

CVE-2023-32233 Linux kernel

0x01 漏洞介绍 近日,研究人员发现了Linux内核的NetFilter框架中的新漏洞(CVE-2023-32233)。该漏洞可被本地用户用于将权限提升为root,并完全控制系统。问题的根源在于tfilter nf_tables是如何处理批处理请求的,经过身…

科研热点|严整“打招呼”, 国自然基金项目评审请托行为禁止清单来了~

为严整“打招呼”顽疾,5月16日,国家自然科学基金委员会网站公告征求《国家自然科学基金项目评审请托行为禁止清单(征求意见稿)》公众意见。意见稿分别对科研人员、依托单位、评审专家、自然科学基金委工作人员等列出禁止行为清单。…

怎么建企业网站?这份指南告诉你需要知道的事项

随着数字化时代的到来,企业网站已经成为了企业发展过程中不可或缺的一部分。而对于初创企业来说,怎么建企业网站可能会面临许多挑战和问题。本文将介绍如何利用建站工具来轻松建立自己的企业网站。 第一步:选择适合你的模板 建站工具提供了…

EasyImage简单图床 - 快速搭建私人图床云盘同时远程访问

文章目录 1.前言2. EasyImage网站搭建2.1. EasyImage下载和安装2.2. EasyImage网页测试2.3.cpolar的安装和注册 3.本地网页发布3.1.Cpolar云端设置3.2 Cpolar内网穿透本地设置 4. 公网访问测试5. 结语 转发自CSDN远程内网穿透的文章:私人图床 - 本地快速搭建简单的E…

LeetCode·每日一题·1335. 工作计划的最低难度·动态规划

作者:小迅 链接:https://leetcode.cn/problems/minimum-difficulty-of-a-job-schedule/solutions/2271898/dong-tai-gui-hua-zhu-shi-chao-ji-xiang-x-4elt/ 来源:力扣(LeetCode) 著作权归作者所有。商业转载请联系作者…

出学校干了 3 年外包,人废了···

如果不是女朋友和我提分手,我估计现在还没醒悟。 大专生,19年通过校招进入湖南某软件公司,干了接近4年的功能测试。今年年初,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我已经…

Python—练习题

文档结构 练习题 练习题 1、使用一行代码实现给定列表的奇偶数分离;list_a [11, 22, 45,17,19,21,76,34,28,59] 答案:此处使用 列表推导式实现; >>> >>> list_a [11, 22, 45,17,19,21,76,34,28,59] >>> part…

JWT(Json Web Token)的原理、渗透与防御

(关于JWT kid安全部分后期整理完毕再进行更新~2023.05.16) JWT的原理、渗透与防御 目录 JWT的原理、渗透与防御含义原理JWT的起源传统session认证问题token与session区别JWT的结构与内容 JWT的攻击和渗透敏感信息泄露空密钥破解密钥爆破CVE-2019-7644 J…

BFT 最前线 |文心一言推出内测专用独立App,谷歌发布 AI 网络安全套件,腾讯机器人业务新突破:自研灵巧手与机械臂首次亮相

文 | BFT机器人 01 科大讯飞将发布星火认知大模型 百度聊天机器人文心一言已经启动邀测一个多月。现在网友发现,文心一言已经推出了内测专用独立App,目前仅提供安卓版。用户可以通过键盘打字输入问题,也可以通过语音方式输入问题&#xff0c…