在 C# 中从 Mixpanel API 获取数据
Getting data from Mixpanel API in C#
我正在尝试从 Mixpanel API 获取数据。 JSON 结果如下所示:
{"computed_at": "2019-11-19T10:36:33.908802+00:00", "legend_size": 1, "data": {"series": ["2019-11-11", "2019-11-12", "2019-11-13"], "values": {"page views": {"2019-11-12": 111, "2019-11-11": 573, "2019-11-13": 209}}}}
我想用以下值填充此对象:
public class ResultData
{
public string Title { get; set; }
public int Value { get; set; }
public string Category { get; set; }
}
具体来说,我希望 ResultData.Value
是 111
、573
和 209
的总和(3 天内的页面浏览量)。谁能帮我弄清楚该怎么做?
这是我目前尝试过的方法:
public async Task<ResultData> GetData()
{
using (var client = new HttpClient())
{
try
{
var formattedDateFrom = DateTime.Today.AddDays(-1).ToString("yyyy-MM-dd");
var formattedDateTo = DateTime.Now.ToString("yyyy-MM-dd");
string baseUrl = "https://mixpanel.com/api/2.0/segmentation?from_date=" + formattedDateFrom + "&to_date=" + formattedDateTo + "&event=patient+-+booking+-+booked+appointment";
var response = await client.GetAsync(baseUrl);
var stringResult = await response.Content.ReadAsStringAsync();
var rawData = JsonConvert.DeserializeObject<ResultData>(stringResult);
var mixpanelResult = new ResultData();
mixpanelResult.Value = rawData.Value;
mixpanelResult.Title = "Page Views";
return await Task.FromResult(mixpanelResult);
} catch (HttpRequestException httpRequestException)
{
// Not sure what to put here but will try and work it out later
}
}
}
我知道 rawData.Value
不正确,因为它需要是页面浏览量的总和,但目前它甚至没有反序列化。当我添加一个断点时,rawData
只不过是 baseUrl
我在这方面有点新手,非常感谢任何帮助。提前致谢!
在你的情况下,你的 json
键是动态的,所以我们不能 deserialize
它基于任何 class 因为它不会匹配你的 json字符串。
我已经尝试使用您的 json
,您可以在其中获得所需密钥的总和。这可能不是最好的解决方案,但它可能会对您有所帮助。
var obj = JObject.Parse("{\"computed_at\": \"2019-11-19T10:36:33.908802+00:00\", \"legend_size\": 1, \"data\": {\"series\": [\"2019-11-11\", \"2019-11-12\", \"2019-11-13\"], \"values\": {\"page views\": {\"2019-11-12\": 111, \"2019-11-11\": 573, \"2019-11-13\": 209}}}}");
var options = obj["data"]["values"]["page views"].ToList();
var sum = 0;
foreach (var item in options)
{
sum += Convert.ToInt32(item.FirstOrDefault());
}
我正在尝试从 Mixpanel API 获取数据。 JSON 结果如下所示:
{"computed_at": "2019-11-19T10:36:33.908802+00:00", "legend_size": 1, "data": {"series": ["2019-11-11", "2019-11-12", "2019-11-13"], "values": {"page views": {"2019-11-12": 111, "2019-11-11": 573, "2019-11-13": 209}}}}
我想用以下值填充此对象:
public class ResultData
{
public string Title { get; set; }
public int Value { get; set; }
public string Category { get; set; }
}
具体来说,我希望 ResultData.Value
是 111
、573
和 209
的总和(3 天内的页面浏览量)。谁能帮我弄清楚该怎么做?
这是我目前尝试过的方法:
public async Task<ResultData> GetData()
{
using (var client = new HttpClient())
{
try
{
var formattedDateFrom = DateTime.Today.AddDays(-1).ToString("yyyy-MM-dd");
var formattedDateTo = DateTime.Now.ToString("yyyy-MM-dd");
string baseUrl = "https://mixpanel.com/api/2.0/segmentation?from_date=" + formattedDateFrom + "&to_date=" + formattedDateTo + "&event=patient+-+booking+-+booked+appointment";
var response = await client.GetAsync(baseUrl);
var stringResult = await response.Content.ReadAsStringAsync();
var rawData = JsonConvert.DeserializeObject<ResultData>(stringResult);
var mixpanelResult = new ResultData();
mixpanelResult.Value = rawData.Value;
mixpanelResult.Title = "Page Views";
return await Task.FromResult(mixpanelResult);
} catch (HttpRequestException httpRequestException)
{
// Not sure what to put here but will try and work it out later
}
}
}
我知道 rawData.Value
不正确,因为它需要是页面浏览量的总和,但目前它甚至没有反序列化。当我添加一个断点时,rawData
只不过是 baseUrl
我在这方面有点新手,非常感谢任何帮助。提前致谢!
在你的情况下,你的 json
键是动态的,所以我们不能 deserialize
它基于任何 class 因为它不会匹配你的 json字符串。
我已经尝试使用您的 json
,您可以在其中获得所需密钥的总和。这可能不是最好的解决方案,但它可能会对您有所帮助。
var obj = JObject.Parse("{\"computed_at\": \"2019-11-19T10:36:33.908802+00:00\", \"legend_size\": 1, \"data\": {\"series\": [\"2019-11-11\", \"2019-11-12\", \"2019-11-13\"], \"values\": {\"page views\": {\"2019-11-12\": 111, \"2019-11-11\": 573, \"2019-11-13\": 209}}}}");
var options = obj["data"]["values"]["page views"].ToList();
var sum = 0;
foreach (var item in options)
{
sum += Convert.ToInt32(item.FirstOrDefault());
}