从每月数据中按每周截取,每次只截取当前月份的数据,不显示上月

public List<Integer> extraction(List<Integer> days, int wkd) {
    if (wkd < 1 || wkd > 5)
        throw new PreconditionException(400, CodeEnum.PARAM_INVALID.getCode(), "星期数无效");
    if (CollUtil.isEmpty(days))
        return new ArrayList<>();
    Calendar calendar = Calendar.getInstance();
    calendar.setTime(new Date());
    calendar.set(calendar.get(Calendar.YEAR), calendar.get(Calendar.MONTH), 1);
    
    int startWeek = AdTimeUtils.getLocalDateTime(calendar.getTime()).getDayOfWeek().getValue();
    // 需要截取的数量
    int first = 7 - startWeek + 1; // 第一周几天
    int need = wkd == 1 ? first : 7;
    // 第一周,起始0,其余则第一周数量+后续追加数量,后续追加的要排除一页
    int startIndex = wkd == 1 ? 0 : first + (wkd - 2) * need;
    // 起始超出范围,返回空
    if (startIndex >= days.size())
        return new ArrayList<>();
    return days.subList(startIndex, Math.min(days.size(), startIndex + need));
}
public static void main(String[] args) {
    ArrayList<Integer> integers = new ArrayList<>();
    for (int i = 1; i <= 30; i++) {
        integers.add(i);
    }
    DataStatisticsService service = new DataStatisticsService();
    for (int i = 1; i <= 5; i++) {
        List<Integer> extraction = service.extraction(integers, i);
        System.out.println(extraction);
    }
}

在这里插入图片描述

如果你想保持数据流的连续性,而不是每次读取都截取固定长度的数据,可以考虑使用流水线(pipeline)或者分块处理的方式。例如,如果你有一个无限循环,可以在每次循环处理队列的一部分数据,将其转换为10bit,并将结果逐个输出。 下面是一个简单的例子,假设队列的每个元素都是16bit,我们希望每轮循环处理两个元素,生成10bit的新元素: ```systemverilog typedef logic [15:0] input_data; typedef logic [9:0] output_data; // 假设一次处理两个输入元素 localparam WIDTH_PER_CYCLE = 2; reg [15:0] current_input[WIDTH_PER_CYCLE]; wire [14:0] intermediate_data[WIDTH_PER_CYCLE]; // 临时存储区 always @(posedge clk) begin // 检查是否有足够元素处理 if (input_queue.size >= WIDTH_PER_CYCLE) begin for (int i = 0; i < WIDTH_PER_CYCLE; i++) begin current_input[i] = input_queue.pop(); // 对当前元素进行转换 intermediate_data[i] = current_input[i][10:0]; end // 输出10bit数据流 for (int i = 0; i < WIDTH_PER_CYCLE - 1; i++) begin output_data <= intermediate_data[i]; end // 最后一个元素可能会不满10位,处理方式取决于剩余位数 if (current_input[WIDTH_PER_CYCLE - 1].size > 0) begin // ...此处添加处理剩余位数的代码... end end else begin // 队列空或不足以完成一轮处理,暂停输出 end end ``` 注意这个示例是基于连续处理的思路,实际实现会依赖于具体应用的需求和限制。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值