我有一个特定时间段(activationDate到endDate)的服务销售清单。我需要按月份(例如2012年4月)生成销售报告分组。对于每个月我想展示多少整月的使用和多少天。使用日期/月份分组处理列表中的数据
我的类:
public class SaleMonth
{
public DateTime MonthYear { get; set; }//.ToString("Y")
public int FullMonth { get; set; }
public int DaysMonth { get; set; }
public string TotalMonths { get { return String.Format("{0:N2}",
(((FullMonth * 30.5) + DaysMonth)/30.5)); } }
}
我曾尝试:
using (CompanyContext db = new CompanyContext())
{
var saleList = db.MySales.ToList();
DateTime from = saleList.Min(s => s.ActivationDate),
to = saleList.Max(s => s.EndDate);
for (DateTime currDate = from.AddDays(-from.Day + 1)
.AddTicks(-from.TimeOfDay.Ticks);
currDate < to;
currDate = currDate.AddMonths(1))
{
var sm = new SaleMonth
{
MonthYear = currDate,
FullMonth = 0,
DaysMonth = 0
};
var monthSell = saleList.Where(p => p.ActivationDate < currDate.AddMonths(1)
|| p.EndDate > currDate);
foreach (var sale in monthSell)
{
if (sale.ActivationDate.Month == sale.EndDate.Month
&& sale.ActivationDate.Year == sale.EndDate.Year)
{//eg 4/6/13 - 17/6/13
sm.DaysMonth += (sale.EndDate.Day - sale.ActivationDate.Day + 1);
}
else
{
if (sale.ActivationDate.Year == currDate.Year
&& sale.ActivationDate.Month == currDate.Month)
sm.DaysMonth += (currDate.AddMonths(1) - sale.ActivationDate).Days;
else if (sale.EndDate.Year == currDate.Year
&& sale.EndDate.Month == currDate.Month)
sm.DaysMonth += sale.EndDate.Day;
else if(sale.ActivationDate.Date <= currDate
&& sale.EndDate > currDate.AddMonths(1))
sm.FullMonth++;
}
}
vm.SaleMonthList.Add(sm);
}
}
我有我失去了一些东西的感觉,必须有一个更优雅的方式来做到这一点。
Here is a picture显示一些销售和从他们产生的报告。
真的谢谢你!我喜欢填充日期的方式,然后通过它们并相应地获取数据。 除了根据给定的日期检索所有销售对我其他地方非常有用 - 单击报告中每行的“详细信息”。 所以+1两次=) – oCcSking
嗨Ijust在Sum函数上得到这个错误..“只有无参数的构造函数和初始化程序在linq中支持实体”我尝试将addMonth(1)更改为外部var - monthLetter,但是stil get这个例外“你有空闲吗? – oCcSking
@oCcSking,对于Linq-to-Entities,您必须删除所有正在创建的无参数构造函数。如果你看看我的编辑,我已经改变了应该让你再次去的所有查询,并且至少会让你运行来进行调整。 –