- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我基本上是在尝试做与 here 相同的事情只是我想在 C# 中而不是在 SQL 中执行此操作。
我有一个类:
public class AmountPerPeriod
{
public int Id { get; set; }
public DateTime Startdate { get; set; }
public DateTime Enddate { get; set; }
public decimal Amount { get; set; }
}
对于这个例子,假设我填充了一个 AmountPerPeriod
项目列表:
var lstAmountPerPeriod = new List<AmountPerPeriod>()
{
new AmountPerPeriod
{
Id = 1,
Startdate = new DateTime(2019, 03, 21),
Enddate = new DateTime(2019, 05, 09),
Amount = 10000
},
new AmountPerPeriod
{
Id = 2,
Startdate = new DateTime(2019, 04, 02),
Enddate = new DateTime(2019, 04, 10),
Amount = 30000
},
new AmountPerPeriod
{
Id = 3,
Startdate = new DateTime(2018, 11, 01),
Enddate = new DateTime(2019, 01, 08),
Amount = 20000
}
};
我希望我的输出是一个 AmountPerMonth 类列表,如下所示:
public class AmountPerMonth
{
public int Id { get; set; }
public int Year { get; set; }
public int Month { get; set; }
public decimal Amount { get; set; }
}
就像我应该尝试的那样,我得到了一种工作方法,我觉得它的方法很复杂。这种提供正确结果的方法如下所示:
var result = new List<AmountPerMonth>();
foreach (var item in lstAmountPerPeriod)
{
if (item.Startdate.Year == item.Enddate.Year && item.Startdate.Month == item.Enddate.Month)
{
result.Add(new AmountPerMonth
{
Amount = item.Amount,
Id = item.Id,
Month = item.Startdate.Month,
Year = item.Startdate.Year
});
}
else
{
var numberOfDaysInPeriod = (item.Enddate - item.Startdate).Days+1;
var amountPerDay = item.Amount / numberOfDaysInPeriod;
var periodStartDate = item.Startdate;
bool firstPeriod = true;
while (periodStartDate.ToFirstDateOfMonth() <= item.Enddate.ToFirstDateOfMonth())
{
if (firstPeriod)
{
result.Add(new AmountPerMonth
{
Amount = ((periodStartDate.ToLastDateOfMonth()-periodStartDate).Days+1)*amountPerDay,
Id = item.Id,
Month = periodStartDate.Month,
Year = periodStartDate.Year
});
}
else if (periodStartDate.Month != item.Enddate.Month)
{
result.Add(new AmountPerMonth
{
Amount = ((periodStartDate.ToLastDateOfMonth()-periodStartDate.ToFirstDateOfMonth()).Days+1) * amountPerDay,
Id = item.Id,
Month = periodStartDate.Month,
Year = periodStartDate.Year
});
}
else
{
result.Add(new AmountPerMonth
{
Amount = ((item.Enddate - periodStartDate.ToFirstDateOfMonth()).Days+1) * amountPerDay,
Id = item.Id,
Month = periodStartDate.Month,
Year = periodStartDate.Year
});
}
periodStartDate = periodStartDate.AddMonths(1);
firstPeriod = false;
}
}
}
// assert using fluentassertions
result.Count.Should().Be(7);
result.First().Amount.Should().Be(2200);
result.Last().Amount.Should().BeApproximately(2318.84M, 2);
// list with result basically should contain:
// ID |month |year |amount
// ---|------|-------|--------
// 1 |3 | 2019 | 2200.00
// 1 |4 | 2019 | 6000.00
// 1 |5 | 2019 | 1800.00
// 2 |4 | 2019 |30000.00
// 3 |11 | 2018 | 8695.65
// 3 |12 | 2018 | 8985.51
// 3 |1 | 2019 | 2318.84
正如我所说,应该有更简单的方法,甚至可能使用 LINQ。有人有什么建议吗?
提前致谢
最佳答案
使用 LINQ 会容易得多。
var output =
from app in lstAmountPerPeriod
let days = (int)app.Enddate.Date.Subtract(app.Startdate.Date).TotalDays + 1
from day in Enumerable.Range(0, days)
let daily = new AmountPerPeriod()
{
Id = app.Id,
Startdate = app.Startdate.AddDays(day),
Enddate = app.Startdate.AddDays(day),
Amount = app.Amount / days
}
group daily.Amount by new
{
daily.Id,
daily.Startdate.Year,
daily.Startdate.Month
} into gds
select new AmountPerMonth()
{
Id = gds.Key.Id,
Year = gds.Key.Year,
Month = gds.Key.Month,
Amount = gds.Sum(),
};
此查询返回:
关于c# - 将每个日期范围内的金额拆分为每月/每年的金额,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58106660/
我有三个 td,并且正在尝试将每个内部的函数限制为仅该 td。我该怎么做呢?使用此代码,它会获取所有 3 个图像并将它们全部插入到 h2 之前: jQuery("td.frontpage_news")
这是所需的通用公式:if((b2-b1)=c1,True,False但是,我需要 b2-b1约等于 c1 , 在 5 内大约单位(在本例中为秒)。有没有可以处理这个的函数? 最佳答案 你也可以试试这个
我有三个整数,作为命令行参数传入后赋值给变量。我想验证每个整数都在 1-5 范围内。有没有一种方法可以在不使用如下所示的 if 语句的情况下在 Java 中完成此操作?我想避免这样做(注意伪代码):
检查某个变量 X 是否在某个变量 Z 的 n 个数字之内的最简洁方法是什么。n 是任意定义的数字(即 3)。 所以我想要 if (z {something} x){ // run code i
我的顶级 build.gradle (Gradle 2.2) 中有类似的东西 ext.repo = "https://my-artifactory-repo" buildscript { re
我只是在我的 jsp 页面中进行随机技巧和测试。我想使用 Attributes 将 request 范围对象存储在 session 范围对象中。存储后,当尝试从请求属性中提取值(存储在 session
我正在使用 Spring 。我有一个外部化属性文件。我正在按如下方式加载它。 现在我如何将 session 中的属性作为键值对保存? 我尝试编写一个扩展 ServletContextListene
我有以下范围: scope :billable, -> (range_start = nil, range_end = nil) { joins(:bids) .where("au
请看我的示例代码: var testObject = new SomeClass(); using (testObject) { //At this point how can the te
我目前在保持在 vector 范围内时遇到一些问题。 在下面的代码中,我试图检查正在检查的数字是否小于或等于它后面的数字 #include #include #include bool fun(
有人可以帮我解决下面的(简化的)代码吗?我试图从幻灯片事件函数中调用 doTheSlide() 函数。我对 JS 范围的理解仍然有点可疑。 实现这一目标的正确方法是什么?我收到此错误: Uncaugh
如何在 Swift 中检查时间是否在下午 6 点到晚上 11 点之间?我在使用 NSDateFormatter 时遇到了困难,我觉得一定有更简单的方法。 最佳答案 使用NSCalendar: let
我目前正在尝试创建一个 2D 横向滚动条,并且我目前有我的“世界”绘图(暂时是一个大白框),但我无法弄清楚世界地图的边缘与边缘之间的任何关系确保视口(viewport)始终完全被 map 覆盖。 我的
我正在学习李普曼,而且我只是在学习。我在这里尝试编写一个代码,该代码将返回 vector 中的最小元素。当我在 Codeblocks 中编译我的代码时,它说:“模板声明不能出现在 block 范围内”
我有三个日期对象。我该如何比较它们才能确定它们之间的相对差异。 oldDate = newDate() - 5; midDate = newDate() - 2.5; newDate = newDat
我需要检查对象“objCR”是否存在于当前范围内。我尝试使用以下代码。 if(objCR == null) alert("object is not defined"); 让我知道哪里错了。 最佳答案
如何检查 IP 地址是否属于私有(private)类别? if(isPrivateIPAddress(ipAddress)) { //do something } 如有
我正在开发一个 Firefox 插件,它可以转换用户通过用户选择突出显示的屏幕温度。转换后,用户选择将替换为 ID 为 alreadyconverted 的 span HTML 元素,其中包含原始温度
我正在开发一个邮资应用程序,该应用程序需要根据多个邮政编码范围检查整数邮政编码,并根据邮政编码匹配的范围返回不同的代码。 每个代码都有多个邮政编码范围。例如,如果邮政编码在 1000-2429、254
我正在使用 excel 范围进行连接:Set rng = Range("A1:A8")如果范围内的单元格之一为空,则会添加一个空格。 你如何阻止这个空间被添加? 最佳答案 假设您在那些非空单元格中有常
我是一名优秀的程序员,十分优秀!