[英]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.