c# - 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);
}
我希望我能很好地解释我的问题是什么以及我想要实现的目标。如果我没有请让我澄清一下。任何帮助表示赞赏谢谢!
解决方案
我认为@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
推荐阅读
- .net - 存储在 Firestore 中时如何从数组中删除对象
- python - Django-allauth - 使用 OneToOneField 自定义注册
- spreadsheet - 使用 Google Apps 脚本触发器和权限复制电子表格
- c# - C# 不转义 Lucene 查询中的搜索运算符
- blazor - 如何从 Blazor 中的组件获取更新的单例属性?
- javascript - 错误尝试通过 callign firebase.app() 使用未安装在您的 Android 项目上的 firebase 模块
- nexus - 从 Nexus 下载最高版本号的工件
- python - 如何将一个图形的轴分配给另一个图形的轴?
- python-3.x - TF-TRT 无法在 JetsonNano 中构建引擎
- windows - Windows 上的 glext.h