首页 > 解决方案 > 查找给定日期的所有过帐日期(会计)

问题描述

我正在编写一份会计报告,其中一份报告需要列出从给定日期起过去四个星期内的所有发布日期。

发布日期是一周的最后一天,在我们的例子中是星期天或一个月的最后一天。

例如。如果我输入 2019 年 12 月 1 日,那么我将列出以下列表:

正如您在此处看到的,有 5 个发布日期。有时有4周。

以下是 4 个发布日期的示例:结束周 10/27/2019

输入值将始终为星期日,即周末。

我想知道是否有一个经过测试的库已经具有这种功能,而不是编写我自己的逻辑来处理日期。

标签: javadateaccounting

解决方案


java.time

我怀疑经过测试的库是否能准确提供您所要求的内容,尽管您可以使用搜索引擎试试运气。使用现代 Java 日期和时间 API java.time,自己编写代码并不难。有很多方法可以解决这个问题。以下内容对我来说很自然:

public static List<LocalDate> getPostDates(LocalDate endDate) {
    DayOfWeek dow = endDate.getDayOfWeek();
    if (! dow.equals(DayOfWeek.SUNDAY)) {
        throw new IllegalArgumentException("End date must be Sunday, was " + dow);
    }

    List<LocalDate> result = new ArrayList<>(5);
    for (int week = 1; week <= 4; week++) {
        LocalDate lastDayOfWeek = endDate.minusWeeks(week - 1);
        result.add(lastDayOfWeek);
        // If the week crosses a month boundary, also add last day of month
        int dom = lastDayOfWeek.getDayOfMonth();
        if (dom < 7) {
            result.add(lastDayOfWeek.minusDays(dom));
        }
    }

    return result;
}

让我们用您的两个示例日期进行尝试:

    System.out.println(getPostDates(LocalDate.of(2019, Month.DECEMBER, 1)));
    System.out.println(getPostDates(LocalDate.of(2019, Month.OCTOBER, 27)));

输出是:

[2019-12-01, 2019-11-30, 2019-11-24, 2019-11-17, 2019-11-10]
[2019-10-27, 2019-10-20, 2019-10-13, 2019-10-06, 2019-09-30]

我注意到最后一个示例包括 9 月 30 日,您的问题中没有提到。不过,它是在 10 月 27 日后的最后四个星期内,而且是月底,所以我认为这是正确的吗?

只有 4 个发布日期的示例:

    System.out.println(getPostDates(LocalDate.of(2019, Month.SEPTEMBER, 29)));
    System.out.println(getPostDates(LocalDate.of(2019, Month.JULY, 14)));
[2019-09-29, 2019-09-22, 2019-09-15, 2019-09-08]
[2019-07-14, 2019-07-07, 2019-06-30, 2019-06-23]

链接: Oracle 教程:解释如何使用 java.time 的日期时间。


推荐阅读