我正在尝试解析JSON以获取特定的行。我在google上尝试了很多不同的东西,我可以找到它,这就像我能得到的一样。
我想读什么:
[{
"id": "pinkcoin",
"name": "PinkCoin",
"symbol": "PINK",
"rank": "321",
"price_usd": "0.0281999",
"price_btc": "0.00000165",
"24h_volume_usd": "195433.0",
"market_cap_usd": "10470475.0",
"available_supply": "371294750.0",
"total_supply": "388294750.0",
"max_supply": null,
"percent_change_1h": "5.48",
"percent_change_24h": "10.83",
"percent_change_7d": "-7.62",
"last_updated": "1513043947"
}]
我试图从这里拉出“price_usd”部分......下面是使用的代码:
var request = require('request');
request('https://api.coinmarketcap.com/v1/ticker/pinkcoin/', function (error, response, body) {
fs.readFile(body, 'utf8', function (err, data) {
if (err) {
console.log('Error: ' + err);
return;
}
data = JSON.parse(data);
bot.sendMessage({
to: channelID,
message: data.price_usd
});
});
});
但是当我触发此代码时,我会在控制台中看到它:
Error: Error: ENAMETOOLONG: name too long, open '[{
"id": "pinkcoin",
"name": "PinkCoin",
"symbol": "PINK",
"rank": "319",
"price_usd": "0.0284066",
"price_btc": "0.00000166",
"24h_volume_usd": "195093.0",
"market_cap_usd": "10547221.0",
"available_supply": "371294750.0",
"total_supply": "388294750.0",
"max_supply": null,
"percent_change_1h": "6.15",
"percent_change_24h": "11.55",
"percent_change_7d": "-6.97",
"last_updated": "1513044245"
}]'
我一直在寻求解决这个问题,但我无处可去......
答案 0 :(得分:1)
我不确定你为什么要在fs.readFile
使用path
。您正在获取api call的结果,返回整个JSON对象,并将其用作fs.readFile
的ENAMETOOLONG
参数。该JSON对象是一个非常长的字符串,并且它允许比文件路径长,因此会抛出body
。
来自request
的{{1}}值应该已经拥有您想要的JSON。除非您想根据coinmarketcap API的响应中的值读取文件系统中的某个文件,否则请使用fs
删除该部分。
编辑:另外,作为奖励,您也没有正确使用结果。它返回一个数组,第一个对象有你的结果。我不完全确定它在哪种情况下会返回多个值。所以你想要这个:
bot.sendMessage({
to: channelID,
message: data.price_usd
});
......看起来像这样:
bot.sendMessage({
to: channelID,
message: data[0].price_usd
});