`
beneo
  • 浏览: 55352 次
  • 性别: Icon_minigender_1
  • 来自: 希伯來
社区版块
存档分类
最新评论

Gregorian Calendar ------ 有趣的日历

    博客分类:
  • java
阅读更多
项目有个需求,每天生成一个文件。开始觉得用一个TimeTask或者ScheduledThreadPoolExecutor或者quartz来做,突然觉得太overweight了。后来想到了log4j的DailyRollingFileAppender,果然是我想要的,类似于quartz,通过与类似nextFireTime的参数作比较,判断是否触发append到新文件,不过这不是这篇博文要讲的。我有注意到了这个类,在DailyRollingFileAppender有个inner class RollingCalendar。

这个类的作用也说明了,是computes the start of the next interval
/**
 *  RollingCalendar is a helper class to DailyRollingFileAppender.
 *  Given a periodicity type and the current time, it computes the
 *  start of the next interval.  
 * */
class RollingCalendar extends GregorianCalendar {
  // ...... 不关心,省略掉好了
  }



本人才疏学浅,真的不知道为啥GregorianCalendar要叫这个英文名字,一看原来还是jdk自带的类。。所有膜拜了一下google,wiki大神,与大家分享一下

以下是来自API的翻译:
引用

GregorianCalendar 是 Calendar 的一个具体子类,提供了世界上大多数国家/地区使用的标准日历系统。

GregorianCalendar 是一种混合日历,在单一间断性的支持下同时支持儒略历格里高利历系统,在默认情况下,它对应格里高利日历创立时的格里高利历日期(某些国家/地区是在 1582 年 10 月 15 日创立,在其他国家/地区要晚一些)。可由调用者通过调用 setGregorianChange() 来更改起始日期。

历史上,在那些首先采用格里高利历的国家/地区中,1582 年 10 月 4 日(儒略历)之后就是 1582 年 10 月 15 日(格里高利历)。此日历正确地模拟了这些变化。在开始格里高利历之前,GregorianCalendar 实现的是儒略历。格里高利历和儒略历之间的唯一区别就是闰年规则。儒略历指定每 4 年就为闰年,而格里高利历则忽略不能被 400 整除的世纪年

GregorianCalendar 可实现预期的 格里高利历和儒略历。也就是说,可以通过在时间上无限地向后或向前外推当前规则来计算日期。因此,对于所有的年份,都可以使用 GregorianCalendar 来生成有意义并且一致的结果。但是,采用现代儒略历规则时,使用 GregorianCalendar 得到的日期只在历史上从公元 4 年 3 月 1 日之后是准确的。在此日期之前,闰年规则的应用没有规则性,在 45 BC 之前,甚至不存在儒略历。

在格里高利历创立以前,新年是 3 月 25 日。为了避免混淆,此日历始终使用 1 月 1 日为新年。如果想要格里高利历转换之前并且处于 1 月 1 日和 3 月 24 日之间的日期,则可以进行手动调整。

为 WEEK_OF_YEAR 字段所计算的值的范围从 1 到 53。一年的第一个星期始于 getFirstDayOfWeek() 的最早 7 天,至少包含该年的 getMinimalDaysInFirstWeek() 各天。这取决于 getMinimalDaysInFirstWeek()、getFirstDayOfWeek() 的值以及 1 月 1 日是星期几。一年的第一个星期和下一年的第一个星期之间的各个星期按顺序从 2 到 52 或 53(根据需要)进行编号。

例如,1998 年 1 月 1 日是星期四。如果 getFirstDayOfWeek() 为 MONDAY,并且 getMinimalDaysInFirstWeek() 为 4(这些值反映了 ISO 8601 和很多国家/地区标准),则 1998 年的第一个星期开始于 1997 年 12 月 29 日,结束于 1998 年 1 月 4 日。但是,如果 getFirstDayOfWeek() 为 SUNDAY,那么 1998 年的第一个星期开始于 1998 年 1 月 4 日,结束于 1998 年 1 月 10 日;1998 年头三天是 1997 年第 53 个星期的一部分。

为 WEEK_OF_MONTH 字段所计算的值的范围从 0 到 6。一个月的第一个星期(WEEK_OF_MONTH = 1 的日期)是该月至少连续 getMinimalDaysInFirstWeek() 天中的最早日期,结束于 getFirstDayOfWeek() 的前一天。与一年的第一个星期不同,一个月的第一个星期可能短于 7 天,也不必从 getFirstDayOfWeek() 这一天开始,并且不包括前一个月的日期。在第一个星期之前该月日期的 WEEK_OF_MONTH 为 0。

例如,如果 getFirstDayOfWeek() 为 SUNDAY,getMinimalDaysInFirstWeek() 为 4,那么 1998 年 1 月的第一个星期是从 1 月 4 日星期日到 1 月 10 日星期六。这些天的 WEEK_OF_MONTH 为 1。1 月 1 日星期四到 1 月 3 日星期六的 WEEK_OF_MONTH 为 0。如果 getMinimalDaysInFirstWeek() 变为 3,则 1 月 1 日到 1 月 3 日的 WEEK_OF_MONTH 为 1。

clear 方法将日历字段设置为未定义。GregorianCalendar 为每个日历字段使用以下默认值(如果该值未定义)。


1582年之前的事情就不管了,我们就用好Gregorian历就可以了。上面红色的话,我们用2011年1月1日来做测试看看

实际代码测试:

public class GregorianCalendarDemo {

    private GregorianCalendar calendar;

    public final static int SUNDAY = 1;
    public final static int MONDAY = 2;
    public final static int TUESDAY = 3;
    public final static int WEDNESDAY = 4;
    public final static int THURSDAY = 5;
    public final static int FRIDAY = 6;
    public final static int SATURDAY = 7;


    @BeforeMethod
    public void setup() {
        calendar = new GregorianCalendar();

    }

    @Test
    public void getFirstDayOfWeek_accuracy() {
        // 每周的第一天是周日
        Assert.assertEquals(calendar.getFirstDayOfWeek(), SUNDAY);
        // 设定每周的第一天是周一
        calendar.setFirstDayOfWeek(MONDAY);
        // 每周的第一天是周一
        Assert.assertEquals(calendar.getFirstDayOfWeek(), MONDAY);
    }

    @Test
    public void getFirstWeekOfYear_accuracy() {
        //在我的机器上面,返回的是1,看来中国不属于“ISO 8601 和很多国家/地区标准”
        //这表示,含有2011年第一天的那周,都算为2011年第一周
        Assert.assertEquals(calendar.getMinimalDaysInFirstWeek(), 1);
        calendar.setTime(new GregorianCalendar(2010, 11, 31).getTime());// 这是2010年12月31日, Month value is 0-based.
        Assert.assertEquals(calendar.get(Calendar.WEEK_OF_YEAR), 1); // 这个2011年的第一周

        calendar.setTime(new GregorianCalendar(2010, 11, 26).getTime());// 这是2010年12月25日, Month value is 0-based.
        Assert.assertEquals(calendar.get(Calendar.WEEK_OF_YEAR), 1); // 这也是2011年的第一周

        //让中国属于 “ISO 8601 和很多国家/地区标准”
        calendar.setMinimalDaysInFirstWeek(4);
        //这表示,至少2011年1月份前4天在的同一周,那这一周就视为2011年的,正好只有1、2号在同一周,3、4号不再,那么这周还算2010年的
        Assert.assertEquals(calendar.getMinimalDaysInFirstWeek(), 4);
        calendar.setTime(new GregorianCalendar(2011, 0, 1).getTime());// 这是2011年1月1日, Month value is 0-based.
        Assert.assertEquals(calendar.get(Calendar.WEEK_OF_YEAR), 52); // 这个2010年的第52周

        calendar.setTime(new GregorianCalendar(2011, 0, 2).getTime());// 这是2011年1月2日, Month value is 0-based.
        Assert.assertEquals(calendar.get(Calendar.WEEK_OF_YEAR), 1); // 这个2011年的第1周,因为一周的第一天是SUNDAY

        //但是,如果我们设定一周的开始是周一的话
        calendar.setFirstDayOfWeek(MONDAY);
        Assert.assertEquals(calendar.get(Calendar.WEEK_OF_YEAR), 1); // error 返回说明是2010年的第52周
    }
}

那么,红色部分的说明可以修改为2011年1月1日是星期六,如果 getFirstDayOfWeek() 为 SUNDAY,并且 getMinimalDaysInFirstWeek() 为 1,则 2011 年的第一个星期开始于 2010 年 12 月 26 日,结束于 2011 年 1 月 1 日。
但是,如果 getFirstDayOfWeek() 为 MONDAY,并且getMinimalDaysInFirstWeek() 为4, 那么 2011 年的第一个星期开始于 2010 年 12 月 27 日,结束于 2011 年 1 月 2 日;2011 年头2天是 2010 年第 52 个星期的一部分


WEEK_OF_MONTH可以按照上面的方法自行测试。

GregorianCalendar用于定时任务:

    // 获得下一分钟的时间
    @Test
    public void getNextMinuteTime() {
        Date date = new Date();

        calendar.setTime(date);
        calendar.set(Calendar.SECOND, 0);
        calendar.set(Calendar.MILLISECOND, 0);
        calendar.add(Calendar.MINUTE, 1);
        System.out.println("this time: " + date);
        System.out.println("next minute time: " + calendar.getTime());
    }

    // 获得下周的第一天的时间
    @Test
    public void getTopOfWeekTime() {
        Date date = new Date();

        calendar.setTime(date);
        calendar.set(Calendar.DAY_OF_WEEK, calendar.getFirstDayOfWeek());
        calendar.set(Calendar.HOUR_OF_DAY, 0);
        calendar.set(Calendar.MINUTE, 0);
        calendar.set(Calendar.SECOND, 0);
        calendar.set(Calendar.MILLISECOND, 0);
        calendar.add(Calendar.WEEK_OF_YEAR, 1);
        System.out.println("this time: " + date);
        System.out.println("next week time: " + calendar.getTime());
    }

    // 获得下个月第一天的时间
    @Test
    public void getTopOfMonthTime() {
        Date date = new Date();

        calendar.setTime(date);
        calendar.set(Calendar.DATE, 1);
        calendar.set(Calendar.HOUR_OF_DAY, 0);
        calendar.set(Calendar.MINUTE, 0);
        calendar.set(Calendar.SECOND, 0);
        calendar.set(Calendar.MILLISECOND, 0);
        calendar.add(Calendar.MONTH, 1);
        System.out.println("this time: " + date);
        System.out.println("next month time: " + calendar.getTime());
    }


这样自己就能通过Gregoriancalendar实现一个简单的定时任务了。
分享到:
评论
5 楼 tao3618341 2011-02-12  
beneo 写道
项目有个需求,每天生成一个文件。开始觉得用一个TimeTask或者ScheduledThreadPoolExecutor或者quartz来做,突然觉得太overweight了。后来想到了log4j的DailyRollingFileAppender,果然是我想要的,类似于quartz,通过与类似nextFireTime的参数作比较,判断是否触发append到新文件,不过这不是这篇博文要讲的。我有注意到了这个类,在DailyRollingFileAppender有个inner class RollingCalendar。

这个类的作用也说明了,是computes the start of the next interval
/**
 *  RollingCalendar is a helper class to DailyRollingFileAppender.
 *  Given a periodicity type and the current time, it computes the
 *  start of the next interval.  
 * */
class RollingCalendar extends GregorianCalendar {
  // ...... 不关心,省略掉好了
  }



本人才疏学浅,真的不知道为啥GregorianCalendar要叫这个英文名字,一看原来还是jdk自带的类。。所有膜拜了一下google,wiki大神,与大家分享一下

以下是来自API的翻译:
引用

GregorianCalendar 是 Calendar 的一个具体子类,提供了世界上大多数国家/地区使用的标准日历系统。

GregorianCalendar 是一种混合日历,在单一间断性的支持下同时支持儒略历格里高利历系统,在默认情况下,它对应格里高利日历创立时的格里高利历日期(某些国家/地区是在 1582 年 10 月 15 日创立,在其他国家/地区要晚一些)。可由调用者通过调用 setGregorianChange() 来更改起始日期。

历史上,在那些首先采用格里高利历的国家/地区中,1582 年 10 月 4 日(儒略历)之后就是 1582 年 10 月 15 日(格里高利历)。此日历正确地模拟了这些变化。在开始格里高利历之前,GregorianCalendar 实现的是儒略历。格里高利历和儒略历之间的唯一区别就是闰年规则。儒略历指定每 4 年就为闰年,而格里高利历则忽略不能被 400 整除的世纪年

GregorianCalendar 可实现预期的 格里高利历和儒略历。也就是说,可以通过在时间上无限地向后或向前外推当前规则来计算日期。因此,对于所有的年份,都可以使用 GregorianCalendar 来生成有意义并且一致的结果。但是,采用现代儒略历规则时,使用 GregorianCalendar 得到的日期只在历史上从公元 4 年 3 月 1 日之后是准确的。在此日期之前,闰年规则的应用没有规则性,在 45 BC 之前,甚至不存在儒略历。

在格里高利历创立以前,新年是 3 月 25 日。为了避免混淆,此日历始终使用 1 月 1 日为新年。如果想要格里高利历转换之前并且处于 1 月 1 日和 3 月 24 日之间的日期,则可以进行手动调整。

为 WEEK_OF_YEAR 字段所计算的值的范围从 1 到 53。一年的第一个星期始于 getFirstDayOfWeek() 的最早 7 天,至少包含该年的 getMinimalDaysInFirstWeek() 各天。这取决于 getMinimalDaysInFirstWeek()、getFirstDayOfWeek() 的值以及 1 月 1 日是星期几。一年的第一个星期和下一年的第一个星期之间的各个星期按顺序从 2 到 52 或 53(根据需要)进行编号。

例如,1998 年 1 月 1 日是星期四。如果 getFirstDayOfWeek() 为 MONDAY,并且 getMinimalDaysInFirstWeek() 为 4(这些值反映了 ISO 8601 和很多国家/地区标准),则 1998 年的第一个星期开始于 1997 年 12 月 29 日,结束于 1998 年 1 月 4 日。但是,如果 getFirstDayOfWeek() 为 SUNDAY,那么 1998 年的第一个星期开始于 1998 年 1 月 4 日,结束于 1998 年 1 月 10 日;1998 年头三天是 1997 年第 53 个星期的一部分。

为 WEEK_OF_MONTH 字段所计算的值的范围从 0 到 6。一个月的第一个星期(WEEK_OF_MONTH = 1 的日期)是该月至少连续 getMinimalDaysInFirstWeek() 天中的最早日期,结束于 getFirstDayOfWeek() 的前一天。与一年的第一个星期不同,一个月的第一个星期可能短于 7 天,也不必从 getFirstDayOfWeek() 这一天开始,并且不包括前一个月的日期。在第一个星期之前该月日期的 WEEK_OF_MONTH 为 0。

例如,如果 getFirstDayOfWeek() 为 SUNDAY,getMinimalDaysInFirstWeek() 为 4,那么 1998 年 1 月的第一个星期是从 1 月 4 日星期日到 1 月 10 日星期六。这些天的 WEEK_OF_MONTH 为 1。1 月 1 日星期四到 1 月 3 日星期六的 WEEK_OF_MONTH 为 0。如果 getMinimalDaysInFirstWeek() 变为 3,则 1 月 1 日到 1 月 3 日的 WEEK_OF_MONTH 为 1。

clear 方法将日历字段设置为未定义。GregorianCalendar 为每个日历字段使用以下默认值(如果该值未定义)。


1582年之前的事情就不管了,我们就用好Gregorian历就可以了。上面红色的话,我们用2011年1月1日来做测试看看

实际代码测试:

public class GregorianCalendarDemo {

    private GregorianCalendar calendar;

    public final static int SUNDAY = 1;
    public final static int MONDAY = 2;
    public final static int TUESDAY = 3;
    public final static int WEDNESDAY = 4;
    public final static int THURSDAY = 5;
    public final static int FRIDAY = 6;
    public final static int SATURDAY = 7;


    @BeforeMethod
    public void setup() {
        calendar = new GregorianCalendar();

    }

    @Test
    public void getFirstDayOfWeek_accuracy() {
        // 每周的第一天是周日
        Assert.assertEquals(calendar.getFirstDayOfWeek(), SUNDAY);
        // 设定每周的第一天是周一
        calendar.setFirstDayOfWeek(MONDAY);
        // 每周的第一天是周一
        Assert.assertEquals(calendar.getFirstDayOfWeek(), MONDAY);
    }

    @Test
    public void getFirstWeekOfYear_accuracy() {
        //在我的机器上面,返回的是1,看来中国不属于“ISO 8601 和很多国家/地区标准”
        //这表示,含有2011年第一天的那周,都算为2011年第一周
        Assert.assertEquals(calendar.getMinimalDaysInFirstWeek(), 1);
        calendar.setTime(new GregorianCalendar(2010, 11, 31).getTime());// 这是2010年12月31日, Month value is 0-based.
        Assert.assertEquals(calendar.get(Calendar.WEEK_OF_YEAR), 1); // 这个2011年的第一周

        calendar.setTime(new GregorianCalendar(2010, 11, 26).getTime());// 这是2010年12月25日, Month value is 0-based.
        Assert.assertEquals(calendar.get(Calendar.WEEK_OF_YEAR), 1); // 这也是2011年的第一周

        //让中国属于 “ISO 8601 和很多国家/地区标准”
        calendar.setMinimalDaysInFirstWeek(4);
        //这表示,至少2011年1月份前4天在的同一周,那这一周就视为2011年的,正好只有1、2号在同一周,3、4号不再,那么这周还算2010年的
        Assert.assertEquals(calendar.getMinimalDaysInFirstWeek(), 4);
        calendar.setTime(new GregorianCalendar(2011, 0, 1).getTime());// 这是2011年1月1日, Month value is 0-based.
        Assert.assertEquals(calendar.get(Calendar.WEEK_OF_YEAR), 52); // 这个2010年的第52周

        calendar.setTime(new GregorianCalendar(2011, 0, 2).getTime());// 这是2011年1月2日, Month value is 0-based.
        Assert.assertEquals(calendar.get(Calendar.WEEK_OF_YEAR), 1); // 这个2011年的第1周,因为一周的第一天是SUNDAY

        //但是,如果我们设定一周的开始是周一的话
        calendar.setFirstDayOfWeek(MONDAY);
        Assert.assertEquals(calendar.get(Calendar.WEEK_OF_YEAR), 1); // error 返回说明是2010年的第52周
    }
}

那么,红色部分的说明可以修改为2011年1月1日是星期六,如果 getFirstDayOfWeek() 为 SUNDAY,并且 getMinimalDaysInFirstWeek() 为 1,则 2011 年的第一个星期开始于 2010 年 12 月 26 日,结束于 2011 年 1 月 1 日。
但是,如果 getFirstDayOfWeek() 为 MONDAY,并且getMinimalDaysInFirstWeek() 为4, 那么 2011 年的第一个星期开始于 2010 年 12 月 27 日,结束于 2011 年 1 月 2 日;2011 年头2天是 2010 年第 52 个星期的一部分


WEEK_OF_MONTH可以按照上面的方法自行测试。

GregorianCalendar用于定时任务:

    // 获得下一分钟的时间
    @Test
    public void getNextMinuteTime() {
        Date date = new Date();

        calendar.setTime(date);
        calendar.set(Calendar.SECOND, 0);
        calendar.set(Calendar.MILLISECOND, 0);
        calendar.add(Calendar.MINUTE, 1);
        System.out.println("this time: " + date);
        System.out.println("next minute time: " + calendar.getTime());
    }

    // 获得下周的第一天的时间
    @Test
    public void getTopOfWeekTime() {
        Date date = new Date();

        calendar.setTime(date);
        calendar.set(Calendar.DAY_OF_WEEK, calendar.getFirstDayOfWeek());
        calendar.set(Calendar.HOUR_OF_DAY, 0);
        calendar.set(Calendar.MINUTE, 0);
        calendar.set(Calendar.SECOND, 0);
        calendar.set(Calendar.MILLISECOND, 0);
        calendar.add(Calendar.WEEK_OF_YEAR, 1);
        System.out.println("this time: " + date);
        System.out.println("next week time: " + calendar.getTime());
    }

    // 获得下个月第一天的时间
    @Test
    public void getTopOfMonthTime() {
        Date date = new Date();

        calendar.setTime(date);
        calendar.set(Calendar.DATE, 1);
        calendar.set(Calendar.HOUR_OF_DAY, 0);
        calendar.set(Calendar.MINUTE, 0);
        calendar.set(Calendar.SECOND, 0);
        calendar.set(Calendar.MILLISECOND, 0);
        calendar.add(Calendar.MONTH, 1);
        System.out.println("this time: " + date);
        System.out.println("next month time: " + calendar.getTime());
    }


这样自己就能通过Gregoriancalendar实现一个简单的定时任务了。

4 楼 fan2012 2011-01-21  
这些东西不是很基础吗
3 楼 Technoboy 2011-01-21  
写的什么?
2 楼 xifo 2011-01-20  
格林威治历,记得微软的Windows(好像是XP和之前的版本)在日历处理上就有个Bug,但JDK的这个实现目前还没有发现什么问题。
1 楼 ybyonline 2010-12-03  
GregorianCalendar:罗马日历,

相关推荐

    Lucky and Good Months by Gregorian Calendar Kaohsiung 2006代码

    Kaohsiung 2006 Lucky and Good Months by Gregorian Calendar(ACM HNU 11562 题 代码) 对于日历的处理,类似于10013的题目

    Go-go-persian-calendar-Persian(SolarHijri)日历在Go(golang)中的一个实现

    "Go-go-persian-calendar-Persian(SolarHijri)日历在Go(golang)中的一个实现"这个项目就是针对伊朗和阿富汗等地区广泛使用的波斯日历(也称为太阳希吉来历)的一个实现,提供了在Go语言中操作和转换波斯日历的能力。...

    KendoUI_Gregorian-Persian-Hijri_Calendar-DatePicker-TimePicker:带有时间和日期选择器的阳历,阴历和阳历

    KendoUI阳历,波斯语,回历(伊斯兰)日历,DatePicker,TimePicker تقویمشمسی,قمریومیلادیبههمراهانتخابگرتاریخوزمان这个项目是一个分支来自: : 这个项目需要...

    Persian-Calendar-for-Gnome-Shell:Gnome-Shell的扩展,以显示波斯日期日历

    波斯语的Gnome-Shell日历 Gnome-Shell的扩展,以显示波斯日期和日历 安装: 克隆存储库 转到克隆的目录 运行make 重新启动Gnome-shell。 (ALT + F2,r,Enter) 您可能需要通过Gnome Tweaks启用扩展 链接: :...

    java的calendar具体用法

    Java默认提供的日历系统是“Gregorian Calendar”,这是一种广泛使用的公历系统。 #### 三、Gregorian Calendar的介绍 “Gregorian Calendar”是一种以罗马教皇格里高利十三世的名字命名的日历系统。该日历系统于...

    ios-日历.zip

    创建自定义日历的第一步通常是初始化一个`NSCalendar`对象,选择合适的日历类型,例如公历(Gregorian): ```swift let calendar = NSCalendar(calendarIdentifier: .gregorian) ``` 接下来,我们可以利用`...

    jalali-calendar:一个将Gregorian转换为Jalali(或将Jalali转换为Gregorian)的Java库

    贾拉利日历 一个将Gregorian转换为Jalali(或将Jalali转换为Gregorian)的Java库。对于Gregorian日期,它使用Java8的日期,而对于Jalali日期则具有自己的代码,这些代码均受Java8的启发。 如何使用jalali-calendar?...

    persian-calendar:Java波斯日历库-开源

    通过扩展GregorianCalendar,PersianCalendar支持:将Gregorian转换为Persian Calendar系统,反之亦然。 将年,月,日,小时,分钟等添加到当前日期解析字符串并产生PersianCalendar ?! 将来发布! 摆动基准日期...

    react-native-general-calendars:React本机日历组件:tear-off_calendar:

    React本机通用日历 :sparkles: :spiral_calendar: :tear-off_calendar: 该模块包括各种可自定义的react native日历组件。 该软件包同时兼容Android和iOS 。安装$ yarn add react-native-general-calendars 或者$ npm...

    JAVA Calendar方法详解.doc

    在Java编程语言中,`Calendar`类是一个核心的日期和时间API,它用于处理各种日历系统,而不仅仅是常见的格里高利历(Gregorian Calendar)。`Calendar`是一个抽象类,这意味着它不能直接被实例化,但是提供了`...

    use-gregorian:React的无头日历钩

    use-gregorian的目标是提供构建日历或日期选择器所需的所有功能,同时让UI和UX由您自己决定。 发展 # install dependencies yarn # run storybook yarn storybook # make sure you didn't break nothing yarn test ...

    c/c++ calendar

    在计算机科学中,日历通常基于公历(Gregorian Calendar)进行构建,该系统以公元1582年为基准,包含了年、月、日的概念,并有闰年规则。闰年每四年出现一次,除非那一年能被100整除但不能被400整除。掌握这些基础是...

    C语言日历算法及对文件操作(把日历打印到TXT)

    首先,日历算法是基于格里高利历(Gregorian Calendar)进行计算的,它涉及到月份天数的确定、闰年的判断以及星期的计算。在C语言中,我们可以使用结构体来存储年月日等信息。例如: ```c struct Date { int year;...

    mysql日历数据表(公历表和农历表,1900-2100年)

    然后,`calendar.sql`文件可能包含了公历日历的数据表,设计可能与`lunar.sql`类似,但没有农历相关字段,且可能包含额外的字段,如: 1. `week_day`:公历日期对应的星期几,整数类型,1代表周一,7代表周日。 2. ...

    纯swift实现日历Demo

    我们可以使用`current`属性获取当前系统日历,或者通过`iso8601`、`gregorian`等常量获取其他日历类型。 在实现日历视图时,我们通常会创建一个自定义的日历视图控制器,继承自`UIViewController`。在这个控制器中...

    bangla-calendar:用于将公历转换为奉爱的shell脚本

    A shell script convert Gregorian calendar into Bongabdo 安装和使用: 'git clone ' 进入目录并授予权限 帮助: bncal -h 孟加拉今天约会: bncal 孟加拉日期在给定的日期,例如。 1952年2月21日 bncal -d 21 ...

    react-date-object:用于处理不同日历和本地日期和时间的 JavaScript 库

    支持的日历: gregorian 、 persian 、 arabic 、 indian默认: gregorian 支持的语言环境: en 、 fa 、 ar 、 hi默认值: en NodeJs: 2.0.0 之前的版本 2.0.0 之前的版本输入calendars和locales的方式不同。 ...

    GUI - 日历转换器:将日历格式从公历格式转换为朱利安格式,反之亦然-matlab开发

    1. **公历(Gregorian Calendar)**:也称为格里高利历,是目前国际上普遍采用的标准日历。公历以基督诞生年为公元元年,分为公元前和公元后。公历月份有30天和31天的设定,并有一个闰年的规则,即能被4整除的年份是...

    2017年日历每月一张+完整打印 含阴历

    公历(阳历)是指按照地球绕太阳公转一周的周期来计算时间的历法,也称为格里历(Gregorian calendar),以1月1日作为新的一年的开始,以12月31日作为一年的结束。公历有固定的天数,平年为365天,闰年为366天。 ...

    PHP 的一个简单的日历

    $days_in_month = cal_days_in_month(CAL_GREGORIAN, $month, $year); // 初始化日历网格 $calendar = array(); for ($i = 0; $i ; $i++) { $calendar[$i] = array_fill(0, 7, ''); } ``` 然后,我们需要填充日历...

Global site tag (gtag.js) - Google Analytics