前提
【DB Models】
day_info_today: 指定日の情報が格納されているテーブル。実装済み。
day_info_diff: 指定日とその前日の情報との差分が格納されているテーブル。未実装。
実現したいこと
day_info_todayから指定日とその前日の情報を取得し、差分を計算。その後、day_info_diffに計算結果を格納したい。
試したこと
試してみた処理は以下のようなものです
①day_info_todayから全情報を取得(配列化)
②配列からインデックスで当日と前日の情報を取得し処理
③処理結果をday_info_diffへ格納
④インデックスを+1し次の情報へ→①へ戻る
生じた問題
forでインデックスを回していたのですが、非同期処理であるため、処理が終了する前にforがループしてしまいました。結果、全要素を処理することができませんでした。
質問
実現目標を達成するためには、どのような処理が必要でしょうか?
また、もっとスマートな方法をご存じであるならば、教えていただければ助かります。
よろしくお願いいたします。
DB1を更新したのち全情報を取得、それらを処理するコード
node
1'use strict'; 2/** TotalとDiff、2つのDBに初期値をセットするプログラムです */ 3const fs = require('fs'); 4const csvParse = require('csv-parse'); 5 6// モデルの読み込み 7const Day_info_total = require('../models/day_info_total'); 8const Day_info_diff = require('../models/day_info_diff'); 9Day_info_total.sync(); 10Day_info_diff.sync(); 11 12// DBに格納する情報の大本。要素数約5000個 13const path = './downloads/all/total/all.tsv'; 14 15function setTotalDatas(path) { 16 return new Promise((resolve) => { 17 // tsvをJsonに変換する処理 18 var rs = fs.createReadStream(path, 'utf-8'); 19 var parser = csvParse({ 20 delimiter: '\t', 21 columns: ['date', 'time', 'unixTime', 'videos', 'views', 'comments'], 22 }); 23 rs.pipe(parser).on('data', (data) => { 24 // Day_info_totalを更新する 25 Day_info_total.create({ 26 date: data['date'], 27 time: data['time'], 28 unixTime: data['unixTime'] , 29 totalVideos: data['videos'], 30 totalViews: data['views'], 31 totalComments: data['comments'], 32 }); 33 }).on('end', () => { 34 resolve(); 35 }); 36 }); 37} 38 39setTotalDatas(path).then(() => { 40 Day_info_total.findAll().then((datas) => { 41 // 【問題箇所】全要素に対して処理を行いが、非同期であるため処理が終わる前にループする。 42 for (let i = 1; i < datas.length; i++) { 43 // 処理内容 44 console.log(datas[i]); 45 } 46 }).catch((err) => { 47 console.info('err', err); 48 }); 49});
補足情報(FW/ツールのバージョンなど)
Node
DB操作はsequelizeで行っています。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。