file.json.gz - SyntaxError unexpected end of data at line 1 column 1 of the JSON data

Hi guys, first I want to apologize if this question is extremely stupid but I have no clue how would I even begin to solve this issue. Anyway, I am fetching a file export from The Movie DB. http://files.tmdb.org/p/exports/movie_ids_11_22_2022.json.gz If you open this file you will see that its a json with objects that are not seperated with commas, therefor I can not "extract" stuff out of them. I am doing all of this in React with package called Pako which essentially handles the zip, right. code:
useEffect(() => {
async function exec(i = 0) {
console.group('file: ', i);
try {

const res = await fetch(urls[i], {
mode: 'no-cors'
});
// convert to arrayBuffer for further processing
const buf = await res.arrayBuffer();
// or get blob using `await res.blob()`
// and convert blob to arrayBuffer using `await blob.arrayBuffer()`

console.log('input size: ', buf.byteLength);

// decompress file
const outBuf = pako.inflate(buf);
// console.log('output size: ', outBuf.byteLength);

// convert arrayBuffer to string
const str = new TextDecoder().decode(outBuf);
// console.log('json string', str);

// print json object
console.log('json object', JSON.parse(str));
} catch (err) {
console.error('unable to decompress', err);
}
console.groupEnd('file: ', i);
}

async function init() {
for (let i in urls) await exec(i)
}
init();

},[])
useEffect(() => {
async function exec(i = 0) {
console.group('file: ', i);
try {

const res = await fetch(urls[i], {
mode: 'no-cors'
});
// convert to arrayBuffer for further processing
const buf = await res.arrayBuffer();
// or get blob using `await res.blob()`
// and convert blob to arrayBuffer using `await blob.arrayBuffer()`

console.log('input size: ', buf.byteLength);

// decompress file
const outBuf = pako.inflate(buf);
// console.log('output size: ', outBuf.byteLength);

// convert arrayBuffer to string
const str = new TextDecoder().decode(outBuf);
// console.log('json string', str);

// print json object
console.log('json object', JSON.parse(str));
} catch (err) {
console.error('unable to decompress', err);
}
console.groupEnd('file: ', i);
}

async function init() {
for (let i in urls) await exec(i)
}
init();

},[])
Do you have any idea how to seperate all of those objects with commas so I can read stuff out of them? Its my first question here so if there is a code formatter sorry for not figuring out where it is 😄 And thanks!!
20 Replies
cropsychooo
cropsychoooOP•3y ago
oh and yes, this is a urls const: const urls = [ 'http://files.tmdb.org/p/exports/movie_ids_11_22_2022.json.gz', ]
Matvey
Matvey•3y ago
please use markdown code block for code ```ts code here ``` It's hard to read code without proper highlighting and monospace font I think you're using wrong decompression algorithm, try pako.ungzip
cropsychooo
cropsychoooOP•3y ago
I edited it @Ronan thank you, since I didnt know how to markdown the code 😄 Ok Imma try this I tried pako.ugnzip but still the same syntaxerror i think I am accessing the file, and its decompressed but it cant read the json properly because no commas
needmorewood
needmorewood•3y ago
i unzipped it manually it does not seem to be valid json on its own but i am going to double check yea i dont think its a valoid json export
Matvey
Matvey•3y ago
yes, looks like you need
const json = str.split('\n').map(d => JSON.parse(d))
const json = str.split('\n').map(d => JSON.parse(d))
needmorewood
needmorewood•3y ago
its also like a 75MB json so u may need to test whats optimal if you can get it in a different format like CSV it might help out or just use their json api if thats applicable to your usecase
cropsychooo
cropsychoooOP•3y ago
Guys, thank you so much. I am not home currently but I will try this once I get my hands on code. I really apperciate your time investment!! And no.. i need these files because there is a popularity value on each movie that changes every day And i need to have files from 5 days in the past so o can have 5 dofferent popularity values to use in chart
needmorewood
needmorewood•3y ago
nice
cropsychooo
cropsychoooOP•3y ago
Sorry I am fat fingering my phone keyboard
needmorewood
needmorewood•3y ago
thats a nice idea for a project ill add it to my never ending list of things i havent done
cropsychooo
cropsychoooOP•3y ago
Hahahaha
cropsychooo
cropsychoooOP•3y ago
Yeah thanks, Its rly nice.. you can check https://marko-movie-app.netlify.app
Movie App
Web site created using create-react-app
cropsychooo
cropsychoooOP•3y ago
Its cool haha
needmorewood
needmorewood•3y ago
ah yes i've seen these demos https://movies.nuxt.space/ and the solid one is pretty insane https://solid-movies.app/ i need to dig into this one on why it feels so good
Nuxt Movies
A TMDB client built with Nuxt Image to show the potential of it ✨
cropsychooo
cropsychoooOP•3y ago
Mm these look cool yeah Yeah this project is for my personal education Its fun to run into problems like this one for instance
needmorewood
needmorewood•3y ago
Yea for sure the ones listed are showcases for frameworks to sort of be like "look what I can do"
cropsychooo
cropsychoooOP•3y ago
Seems like you know your stuff and its why im telling that this gices the same result (syntaxerror) 😦 Ehhhhh this is a tough one
Ambushfall
Ambushfall•3y ago
Hey Cro, I've got a weird solution for you tested working in chrome
const TestFetchMovie = () => {

useEffect(() => {
async function exec() {

// or get blob using `await res.blob()`
// and convert blob to arrayBuffer using `await blob.arrayBuffer()`
try {

const res = await fetch('http://files.tmdb.org/p/exports/movie_ids_11_22_2022.json.gz');
const buf = await res.arrayBuffer();
const outBuf = pako.inflate(buf);
// console.log(outBuf)

const str = new TextDecoder().decode(outBuf);
const jsonString = str.split('\n').join(',').slice(0,-1)
const test = `[${jsonString}]`
console.log(JSON.parse(test));
} catch (err) {
console.error('unable to decompress', err);
}
}

async function init() {
await exec()
}
init();

}, [])
}
const TestFetchMovie = () => {

useEffect(() => {
async function exec() {

// or get blob using `await res.blob()`
// and convert blob to arrayBuffer using `await blob.arrayBuffer()`
try {

const res = await fetch('http://files.tmdb.org/p/exports/movie_ids_11_22_2022.json.gz');
const buf = await res.arrayBuffer();
const outBuf = pako.inflate(buf);
// console.log(outBuf)

const str = new TextDecoder().decode(outBuf);
const jsonString = str.split('\n').join(',').slice(0,-1)
const test = `[${jsonString}]`
console.log(JSON.parse(test));
} catch (err) {
console.error('unable to decompress', err);
}
}

async function init() {
await exec()
}
init();

}, [])
}
Ambushfall
Ambushfall•3y ago
As of right now, I've got it to get parsed and show as such
cropsychooo
cropsychoooOP•3y ago
Woah, yeah man!!! It works!! I managed to do it too yesterday but not 100%, i got.output but weird, thisnis much better thank you duuud

Did you find this page helpful?