gpt4 book ai didi

javascript - 获取 JSON 流的内容

转载 作者:行者123 更新时间:2023-12-01 04:03:54 24 4
gpt4 key购买 nike

在 Node.js 中开发一个机器人,该机器人扩展了另一个机器人创建的数据。该机器人将其所有数据输出到 JSON 页面 https://mee6.xyz/levels/267482689529970698?json=1

但是我看不到 JSONStream 生成的数据的控制台输出。我怎样才能获得它以便将其用于我的扩展系统?

var request = require('request')
, JSONStream = require('JSONStream')
, es = require('event-stream')

request({url: 'https://mee6.xyz/levels/267482689529970698?json=1'})
.pipe(JSONStream.parse('rows.*'))
.pipe(es.mapSync(function (data) {
console.error(data)
var stream = JSONStream.parse(['rows', true, 'doc']) //rows, ANYTHING, doc

stream.on('data', function(data) {
console.log('received:', data);
});
//emits anything from _before_ the first match
stream.on('header', function (data) {
console.log('header:', data) // => {"total_rows":129,"offset":0}
})
}))

最佳答案

有几个问题。您似乎混合了 JSONStream 文档中描述的两种方法。

首先,您请求的 JSON 根本不包含任何名为“row”的字段,这就是为什么它不起作用: .pipe(JSONStream.parse('rows.*'))

要查看输出,您可以执行以下操作:

request({url: 'https://mee6.xyz/levels/267482689529970698?json=1'})
//So I'm getting all the players records
.pipe(JSONStream.parse('players.*'))
.pipe(es.mapSync(function (data) {
console.log(data);
}));

查看 JSONStream 和 JSONPath文档。

第二个是这个流 stream = JSONStream.parse(['rows', true, 'doc']) 创建后就丢失了。你注意使用它。因此,如果您不喜欢第一种方式,您可以这样做:

var stream = JSONStream.parse(['players']);
stream.on('data', function(data) {
console.log('received:', data);
});

stream.on('header', function (data) {
console.log('header:', data);
});

//Pipe your request into created json stream
request({url: 'https://mee6.xyz/levels/267482689529970698?json=1'})
.pipe(stream);

希望这有帮助。

关于javascript - 获取 JSON 流的内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41971756/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com