前端下载文件并按GBK编码解析内容

一、背景

因项目需要上传csv文件并显示曲线和表格,方案是上传文件,然后再将该文件下载下来解析,然后显示曲线和表格显示。

二、现状

上传文件没问题,后端返回文件链接后再下载,下载到文本后解析时出问题了。Windows系统编辑的csv文件,中文是GBK编码,从文件中得到文本,中文部分是乱码,原因是前端默认UTF-8编码。

三、方案

问了机器人,机器人给的第一个方案是iconv,依赖三方库,离线开发再麻烦了。

第二个方案,是以二进制方式下载到文件内容后指定编码进行处理,这个方案更合适,代码如下:

javascript 复制代码
axios.get(url,{responseType:'blob'}).then(blob => {
    // 按GBK编码解析
    const reader = new FileReader();
    reader.readAsText(blob, 'GBK');
    // 解析成功的回调
    reader.onload = () => {
        // 按换行符分割字符串
        let datas = reader.result.split(/[(\r\n)\r\n]+/);
        // 遍历数据
        datas.forEach((item, index) => {
            // 处理数据即可
        });
    };
});

四、结束

第一次使用blob和FileReader,功能还是很强大的,记录一下备忘。

相关推荐
少年姜太公2 小时前
什么?还不知道git cherry pick?
前端·javascript·git
白兰地空瓶3 小时前
🏒 前端 AI 应用实战:用 Vue3 + Coze,把宠物一键变成冰球运动员!
前端·vue.js·coze
Liu.7744 小时前
vue3使用vue3-print-nb打印
前端·javascript·vue.js
松涛和鸣5 小时前
Linux Makefile : From Basic Syntax to Multi-File Project Compilation
linux·运维·服务器·前端·windows·哈希算法
dly_blog5 小时前
Vue 逻辑复用的多种方案对比!
前端·javascript·vue.js
万少5 小时前
HarmonyOS6 接入分享,原来也是三分钟的事情
前端·harmonyos
烛阴6 小时前
C# 正则表达式:量词与锚点——从“.*”到精确匹配
前端·正则表达式·c#
wyzqhhhh6 小时前
京东啊啊啊啊啊
开发语言·前端·javascript
JIngJaneIL6 小时前
基于java+ vue助农电商系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
想学后端的前端工程师6 小时前
【Java集合框架深度解析:从入门到精通-后端技术栈】
前端·javascript·vue.js