列表以按间隔返回特定字段的值

本文关键字:字段 返回 列表 | 更新日期: 2023-09-27 18:21:40

我正在用巨大的数据实现Telerik Chart。图表x轴上的标签重叠。我已经克服了这个问题,但从长远来看是不可靠的。

以下是列表中的字段:

FieldName                DataType
Date                     DATETIME
DateString               STRING
Unit                     DOUBLE
Price                    DOUBLE

X轴标签值来自DateString字段

我实施的解决方案

  1. MIN和MAX Date DateString字段将始终返回
  2. 对于其余部分,返回工作日为"星期一"的值

这是代码-

// Get min and max Date
DateTime minDate = DateTime.Now;
DateTime maxDate = DateTime.Now;
if (dtGas.Rows.Count > 0)
{
    minDate = Convert.ToDateTime(dtGas.Compute("MIN([Date])", ""));
    maxDate = Convert.ToDateTime(dtGas.Compute("MAX([Date])", ""));
}
// Group by 'Date' and 'DateString' | 'SUM' of Unit and 'Price'
var qGas = from x in dtGas.AsEnumerable()
            group x by new
            {
                Date  = x.Field<DateTime>("Date"),
                DateString = x.Field<string>("DateString")
            } into egroup
            let isOne = egroup.Key.Date.DayOfWeek.ToString() == "Monday"
            select new
            {
                Date = egroup.Key.Date,
                DateString = minDate == egroup.Key.Date ?
                                            (
                                                egroup.Key.DateString
                                            ) :
                                            (
                                                maxDate == egroup.Key.Date ?
                                                (
                                                    egroup.Key.DateString
                                                ) :
                                                ( 
                                                    (isOne) ?
                                                    (
                                                        egroup.Key.DateString
                                                    ) :
                                                    (" ")
                                                )                                            
                                            ),
                Unit = egroup.Sum(r => r.Field<double>("Unit")),
                Price = egroup.Sum(r => r.Field<double>("Price")),
            };

此解决方案有助于返回部分值,而不是所有值。因此避免了重叠。但在未来,随着数据的增长,即使是这种解决方案也将失败。

我需要实施的解决方案

一个我一直在想但不知道如何实现的想法是-

  1. MIN和MAX Date DateString字段将始终返回。[和我现在做的一样]
  2. 无论列表项的总计数如何,从MIN和MAX日期间隔返回8个值
    2.a.但如果列表计数小于或等于8,则返回所有值

例如,如果在列表中我有32个值。它应该在DateString字段中总共返回10个值,其余的将是空字符串。

列表以按间隔返回特定字段的值

我建议这样做:

    public static IList<Stock> GetSome(this IList<Stock> input)
    {
        var result = new List<Stock>();
        if (input.Count < 8)
        {
            return input;
        }
        else
        {
            var i = 0;
            for (; i < input.Count; ++i)
            {
                if (i % 8 == 0)
                {
                    result.Add(input[i]);
                }
            }
            if (i % 8 != 0)
            {
                result.Add(input.Last());
            }
        }
        return result;
    }

如果股票不是按时间顺序排列的,我会按日期调用.Sort()。

您可能希望在代码中添加null和空集合检查。