首页 > 解决方案 > C# WPF 制作 7 天移动平均线

问题描述

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

    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);           

     }

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

标签: c#wpfdatagrid

解决方案


我认为@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],然后平均其余元素的权重。您可能想查看跳过https://docs.microsoft.com/en-us/dotnet/api/system.linq.enumerable.skip?view=net-5.0和平均https://docs.microsoft.com/ en-us/dotnet/api/system.linq.enumerable.average?view=net-5.0


推荐阅读