現在、JavaScriptでアクセスしてきたらCSVファイルの中身を検索して
検索結果をJsonで返すWebアプリを作成しています。
CSVファイルの中身の検索はうまくいっていて、
ループの中では配列(lineArray1)の中身がちゃんと入っているのですが
ループから出たところで配列(lineArray1)の中身が空になってしまいます。
配列の中身がちゃんと入る実装方法を教えていただけないでしょうか?
javascript
1const fs = require('fs'); 2const express= require('express'); 3 4const app = express(); 5 6 7app.get('/',(req,res) =>{ 8 9var startDateTime = req.query.StartDateTime; 10var endDateTime = req.query.EndDateTime; 11var lineArray1 = new Array(); 12 13 14var startDateTime2 = new Date(startDateTime.substr(0,4) , Number(startDateTime.substr(4,2))-1, Number(startDateTime.substr(6,2)), 0, 0,0 ); 15var endDateTime2 = new Date( endDateTime.substr(0,4) , Number(endDateTime.substr(4,2))-1, Number(endDateTime.substr(6,2)), 0, 0,0 ); 16var todayDateTime = new Date(); 17todayDateTime.setHours(0); 18todayDateTime.setMinutes(0); 19todayDateTime.setSeconds(0); 20 21for(startDateTime2;startDateTime2<=endDateTime2;startDateTime2.setDate( startDateTime2.getDate() + 1 )) 22{ 23 24var csvFileName='test.csv'; 25 26 27if(todayDateTime == startDateTime2) 28{ 29csvFileName='test.csv' 30} 31else 32{ 33csvFileName=GetFileName(startDateTime2) 34} 35 36 37 38fs.readFile(csvFileName, 'utf8', function (err, data) { 39 var dataArray = data.split(/\r?\n/); 40 41 for(var line of dataArray) 42 { 43 var lineArray2 = line.split(','); 44 var lineDateTime=lineArray2[0]; 45 46 if(CheckOverTime(startDateTime,lineDateTime)) 47 { 48 if(CheckUnderTime(endDateTime,lineDateTime)) 49 { 50 51 lineArray1.push(lineArray2); 52 53 } 54 } 55 56 } 57}); 58 59} 60 61 var json_text = JSON.stringify(lineArray1); 62 63 res.header('Content-Type', 'application/json; charset=utf-8'); 64 res.set({ 'Access-Control-Allow-Origin': '*' }); 65 res.send(json_text); 66console.log(json_text); 67}); 68 69 70 71app.listen('3000',() =>{ 72 console.log('Application started'); 73});
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2022/04/22 08:53 編集
2022/04/22 08:46
2022/04/22 08:54