java对时间序列每x秒进行分组

问题:将一个时间序列每5秒分一组,返回嵌套的list;

原理:int除int会得到一个int(也就是损失精度)

输入:排序后的list,每几秒分组值

bash 复制代码
    private static List<List<Long>> getSerialSlice(List<Long> serialList, long values) {
        return new ArrayList<>(serialList.stream().collect(
                Collectors.groupingBy(timestamp -> timestamp/ values)).values());
    }

测试:

bash 复制代码
    public static void main(String[] args) {
        List<Long> list = new ArrayList<>();
        list.add(1800000L);
        list.add(1801000L);
        list.add(1802000L);
        list.add(1803000L);
        list.add(1804000L);
        list.add(1805000L);
        list.add(1807000L);
        list.add(1808000L);
        list.add(1810000L);
        list.add(1813000L);
        list.add(1816000L);
        list.add(1817000L);
        List<List<Long>> slice = getSerialSlice(list, 5000);
        for (List<Long> longs : slice) {
            System.out.println("longs = " + longs);
        }
    }

结果:

ps:有人就想要12345为一组,而不要01234为一组,也可以:

bash 复制代码
    private static List<List<Long>> getSerialSlice(List<Long> serialList, long values) {
        return new ArrayList<>(serialList.stream().collect(
                Collectors.groupingBy(timestamp -> (timestamp-1000)/ values)).values());
    }
相关推荐
董董灿是个攻城狮5 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
怒放吧德德7 小时前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty
雨中飘荡的记忆9 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
心之语歌11 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
华仔啊12 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang12 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构
AI软著研究员12 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish13 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
Ray Liang14 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
颜酱14 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法