gpt4 book ai didi

c# - linq - 为绘图填写稀疏表

转载 作者:太空宇宙 更新时间:2023-11-03 20:32:04 25 4
gpt4 key购买 nike

我有一个表,其中包含事件 ID pk、日期列和事件类型列。我想使用 linq 来获取每天的事件数。问题是该表是稀疏的,即值不会存储在没有任何事件的日子里。

因为我想将此数据用于折线图,所以我需要用缺失的日期填充数据并将它们的值设为零。

这些是在 linq 中执行此操作的任何方法吗?还是我必须手动执行此操作?

有什么推荐的方法吗?

编辑:

我创建了以下方法:

public string GetDailyData(int month, int year)
{
int days = DateTime.DaysInMonth(year,month);
DateTime firstOfTheMonth = new DateTime(year, month, 1);
PaymentModelDataContext db = new PaymentModelDataContext();
var q = from daynumber in Enumerable.Range(0, days)
let day = firstOfTheMonth.AddDays(daynumber)
join data in db.TrackingEvents on day equals data.timestamp.Day into d2
from x in d2.DefaultIfEmpty()
select Tuple.Create(x.Key, x.Value);

return ParseJson(q);
}

问题是我在“join”关键字上遇到错误:“连接子句中的一个表达式的类型不正确。调用‘GroupJoin’时类型推断失败”

编辑 2:我进行了建议的更改并尝试对结果进行分组。当我将它们发送到解析函数时,我收到一个空对象引用错误。这是新代码:

[WebMethod]
public string GetDailyData(int month, int year)
{
int days = DateTime.DaysInMonth(year, month);
DateTime firstOfTheMonth = new DateTime(year, month, 1);
PaymentModelDataContext db = new PaymentModelDataContext();
var q = from daynumber in Enumerable.Range(0, days)
let day = firstOfTheMonth.AddDays(daynumber)
join data in db.TrackingEvents on day equals data.timestamp.Date into d2
from x in d2.DefaultIfEmpty()
group x by x.timestamp.Date;

return ParseJson(q);
}

以及解析函数:

private string ParseJson<TKey, TValue>(IEnumerable<IGrouping<TKey, TValue>> q)
{
string returnJSON = "[{ \"type\" : \"pie\", \"name\" : \"Campaigns\", \"data\" : [ ";
foreach (var grp in q)
{
double currCount = grp.Count();
if (grp.Key != null)
returnJSON += "['" + grp.Key + "', " + currCount + "],";
else
returnJSON += "['none', " + currCount + "],";
}
returnJSON = returnJSON.Substring(0, returnJSON.Length - 1);
returnJSON += "]}]";

return returnJSON;
}

最佳答案

您应该能够使用 LINQ。一种方法是使用 Enumerable.Range 创建最小日期和最大日期之间的日期集合,然后对稀疏表执行外部联接(使用 GroupJoin)。 (参见 MSDN Reference: How to Perform Outer Joins (C# Programming Guide))

例如,如果 numdays 是日期范围(以天为单位),MinDate 是初始日期,SparseData 是您的稀疏数据,并且 SparseData 有一个实例属性 Day 指定日期,那么你可以这样做:

var q = Enumerable.Range(0, numdays)
.Select(a => MinDate.AddDays(a))
.GroupJoin(
SparseData,
q=>q,
sd=>sd.Day,
(key, value) =>
Tuple.Create(
key,
value.DefaultIfEmpty().First()
)
);

或者,等价地,

  var q2 = from daynumber in Enumerable.Range(0, numdays)
let day = MinDate.AddDays(daynumber)
join data in SparseData on day equals data.Day into d2
from x in d2.DefaultIfEmpty()
select Tuple.Create(x.Key, x.Value);

关于c# - linq - 为绘图填写稀疏表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7049047/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com