我有一个很大的 JSON 文件,包含约 220k 条记录,大小为 223MB。我可以使用名为 Huge JSON Viewew 的程序打开 JSON,这意味着该文件结构良好,但在解析时显示错误。
const fs = require("fs");
const rawdata = fs.readFileSync("jsonFile.json");
let inproceedings = JSON.parse(rawdata);
它显示的错误:
undefined:1
��[
^
SyntaxError: Unexpected token � in JSON at position 0
at JSON.parse (<anonymous>)
at Object.<anonymous> (C:\Users\HP\Desktop\DATA\script\jsonFile.js:6:26)
?[90m at Module._compile (internal/modules/cjs/loader.js:936:30)?[39m
?[90m at Object.Module._extensions..js (internal/modules/cjs/loader.js:947:10)?[39m
?[90m at Module.load (internal/modules/cjs/loader.js:790:32)?[39m
?[90m at Function.Module._load (internal/modules/cjs/loader.js:703:12)?[39m
?[90m at Function.Module.runMain (internal/modules/cjs/loader.js:999:10)?[39m
?[90m at internal/main/run_main_module.js:17:11?[39m
PS C:\Users\HP\Desktop\DATA\script>
最佳答案
问题是,当您读取文件时,它会作为缓冲区读取。读取时使用utf-8
编码
[https://nodejs.org/api/fs.html#fs_fs_readfilesync_path_options ]
const rawdata = fs.readFileSync("jsonFile.json",{encoding: 'utf-8'});
let inproceedings = JSON.parse(rawdata);
关于javascript - 解析大型 JSON 失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58275999/