Как суммировать различия между каждой парой, а затем суммировать результаты каждой пары с использованием nedb

#javascript #arrays #math #foreach #nedb

#javascript #массивы #математика #foreach #nedb

Вопрос:

У меня есть база trades.json данных nedb, в которой я пишу воображаемые биржевые сделки:

 {"buySell":"BUY","currentPrice":431.55,"_id":"GyTaUKVOCa9x5APS"},
{"buySell":"SELL","currentPrice":431.77,"_id":"Re9VhGrW9ZoiOKFe"},
{"buySell":"BUY","currentPrice":431.65,"_id":"TJrn63bIV8sKBFYh"},
{"buySell":"SELL","currentPrice":431.7539,"_id":"qrsz2l3UVKpQEks8"}
  

Я пытаюсь найти разницу currentPrice между каждой buySell парой «BUY» и «SELL», а затем сложить эти два результата вместе, чтобы получить мою общую прибыль.

У меня есть этот код, который работает, но я не уверен, что результат действителен. Я думаю, что это дает мне общую разницу и не показывает мне мою «прибыль» для каждой сделки.

 const Datastore = require('nedb')
const trades = new Datastore({ filename: 'trades.json' })
trades.loadDatabase(function (err) {
    if(err) return console.error(err)
})

let sum = []
trades.find({}).exec(function (err, docs) {

    if(err) return console.log(err)

    docs.forEach(element => {
        sum.push(element.currentPrice)
    });
    let pandle = diff(sum)
    pandle = pandle.reduce((a, b) => a   b, 0)
    
    console.log(pandle)
    
})

function diff(A) {
    return A.slice(1).map(function(n, i) { return n - A[i]; });
}
  

Я полагаю, что мой ответ заключается в цикле foreach, который создает массив bySell пар «BUY» и «SELL», а также другой массив, который отслеживает сумму этих пар, но я изо всех сил пытаюсь заставить его работать.

В приведенном выше примере, я полагаю, я должен получить : 0.3239 .

Я буду признателен за любую помощь или направление!

Комментарии:

1. пожалуйста, добавьте желаемый результат.

Ответ №1:

Вы можете вычесть 'BUY' значения из суммы и добавить 'SELL' значения.

 const
    fns = { BUY: v => -v, SELL: v => v },
    array = [{ buySell: "BUY", currentPrice: 431.55, _id: "GyTaUKVOCa9x5APS" }, { buySell: "SELL", currentPrice: 431.77, _id: "Re9VhGrW9ZoiOKFe" }, { buySell: "BUY", currentPrice: 431.65, _id: "TJrn63bIV8sKBFYh" }, { buySell: "SELL", currentPrice: 431.7539, _id: "qrsz2l3UVKpQEks8" }],
    profit = array.reduce((p, { buySell, currentPrice }) => p   fns[buySell](currentPrice), 0);

console.log(profit);