前端下载文件并按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,功能还是很强大的,记录一下备忘。

相关推荐
于慨1 天前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz1 天前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶2 天前
前端交互规范(Web 端)
前端
CHU7290352 天前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing2 天前
Page-agent MCP结构
前端·人工智能
王霸天2 天前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航2 天前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界2 天前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript
PieroPc2 天前
一个功能强大的 Web 端标签设计和打印工具,支持服务器端直接打印到局域网打印机。Fastapi + html
前端·html·fastapi
悟空瞎说2 天前
深入 Vue3 响应式:为什么有的要加.value,有的不用?从设计到源码彻底讲透
前端·vue.js