繁体   English   中英

C# WPF 形成 7 天移动平均线

[英]C# WPF making a 7-day moving average

嘿,我正在尝试制作 7 天移动平均线,但我不确定如何 go 关于它。 我目前拥有的是用户在 DataGrid 中输入值,然后在输入 7 个数字后,他们得到这些数字的平均值(数字总和 / 7)。 我已经设法实现了这一点,但我想要一个移动平均线,这样当他们输入第 8 个或第 9 个值等时,他们会得到最后 7 个值的新平均值。 我不确定我将如何实现 go。 所以它现在的工作方式是用户通过将值输入到名为“AddWeightToGrid”的文本框中将值输入到 DataGrid 然后该值进入一个名为“gridListValues”的 ObservableCollectionsList,这就是 DataGrids ItemSource(DataGrid 称为“WeightDataGrid”) . 以下是 7 天平均计算现在的样子:

    private void AddWeightToGridButton_Click(object sender, RoutedEventArgs e)
    {
        if (gridListValues.Count <= 5)
            gridListValues.Add(new WeightGridValues { Weight = AddWeightToGrid.Text, Date = Convert.ToString(AddDateToGrid) });

        else if (gridListValues.Count >= 6)
        {
            gridListValues.Add(new WeightGridValues { Weight = AddWeightToGrid.Text, Date = Convert.ToString(AddDateToGrid), SevenDayWeightAverage = SevenDayAverageCalc(averageWeight) });                
        }
    }


     private string SevenDayAverageCalc(WeightGridValues averageWeight)
     {

        decimal sevenDayCalc = 0;
        for (int i = 0; i < gridListValues.Count; i++)
        {
            sevenDayCalc += Convert.ToDecimal(gridListValues[i].Weight);                
        }
        sevenDayCalc += Convert.ToDecimal(AddWeightToGrid.Text);
        sevenDayCalc = sevenDayCalc / 7;
        
        return averageWeight.SevenDayWeightAverage = Convert.ToString(sevenDayCalc);           

     }

我希望我能很好地解释我的问题是什么以及我想要实现的目标。 如果我没有请让我澄清一下。 任何帮助表示赞赏谢谢!

我认为@jdweng 的答案是正确的,但可能需要对@sharpus 进行一些解释,因为他/她是“编程新手”。

让我试着用更基本的方式来解释。 您的 SevenDayAverageCalc() 正在尝试逐个遍历 gridListValues,得到总和,然后除以 7。当且仅当您的 gridListValues 有 7 个元素时,这才有效。 如果元素超过 7 个,则需要跳过前几个元素,只使用最后 7 个元素。所以你可以这样做:

for (int i = gridListValues.count -7; i < gridListValues.count; i++)
{
    sevenDayCalc += Convert.ToDecimal(gridListValues[i].Weight);                
}
sevenDayCalc += Convert.ToDecimal(AddWeightToGrid.Text);
sevenDayCalc = sevenDayCalc / 7;

这实际上是@jdweng 的一行代码正在做的事情:跳过前几行到达[gridListValues.count - 7],然后平均元素权重的rest。 您可能想查看 Skip https://docs.microsoft.com/en-us/dotnet/api/system.linq.enumerable.skip?view=net-5.0和平均Z5E056C500A1C4/7BADE5Z11 en-us/dotnet/api/system.linq.enumerable.average?view=net-5.0

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM