【发布时间】:2018-01-07 06:18:23
【问题描述】:
我一直在研究一个问题,但我似乎无法完全理解其起源。 我的应用程序的工作流程是这样的:
- 为单个请求获取一组项目
- 对该数组的每个项目发出单独的请求:
Promise.all(array.map(individualRequest)) - 从每个请求中获取信息并将其更改为特定布局
- 将数组中所有项的修改信息记录到一个JSON文件中
直到第 4 步,一切似乎都在无缝运行。在第 3 步中,我正确修改了对象,但是当它返回到 main 时(每个步骤都有一个专用模块),第 4 步写道:[null,null,null...](原始中的每个项目都为 null数组)在 JSON 文件中。
我不确定如何将其放入代码中并使其变得简单(不发布整个原始代码),但您可以在此处找到完整版本: https://github.com/Ardzii/mongoNode
我知道项目信息正在被正确转换,因为我在转换模块中留下了一个控制台日志进行验证,它给了我正确的信息:
[添加]: {"name":"DASHEUR","a":["151.400000","1","1.000"],"b":["148.500000","1","1.000"],"c":[ "151.577960","0.01000000"],"v":["1861.79012466","3063.32653118"],"p":["151.527639","150.811326"],"t":[688,1205],"l" :["146.599930","146.599930"],"h":["156.118780","156.118780"],"o":"148.000000"}
我不知道为什么,当它回到主 (app.js) 时:
async function worker() {
var tickerList = await getTickerList();
var tickerInfo = await getTickerInfo(tickerList);
var filename = `./modules/batches/${new Date().toISOString()}batch.json`;
fs.writeFile(filename, JSON.stringify(tickerInfo), (err) => {
if (err) throw err;
console.log("[SUCCESS]: All tickers processed successfully!");
});
}
worker();
我觉得很糟糕
[null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,空,空]
存储在 JSON 文件中...(同样,数组中的每个项目都有一个“null”)
提前感谢您的帮助,我希望我能够保持清晰和简单!
【问题讨论】:
-
如果没有看到您的
getTickerInfo()和getTickerList()函数的作用,就不可能说出问题所在。显然,getTickerInfo()解析为一个充满null的数组 -
您是否意识到
if (err) throw err;在异步回调中不是合理的错误处理? -
嘿jfriend00!一点也不...我完全是初学者,所以如果你有更好的方法和一些材料来对此进行适当的跟进,我会很高兴
标签: javascript json node.js promise async-await