前几天在blog中,对网友的java万年历作修改,看到有的网友说能不能加上农历,后来在网上看到有人写过几个阳历转阴历的算法,我比较了一个发现,这个算法还算不错,只要有的计算机编程基础的人看明白应该是没有问题的,其实这个就和我们以前在c中,判断一天是周几的算法差不多,都是和某一个特定的时间作比较,算出差多少天,再根据月大月小瑞月这些规则,算出是农历的那年那月那日.

Java代码  
  1. package clock;
  2. import java.text.ParseException;
  3. import java.text.SimpleDateFormat;
  4. import java.util.Calendar;
  5. import java.util.Date;
  6. public class Lunar {
  7. private int year;
  8. private int month;
  9. private int day;
  10. private boolean leap;
  11. final static String chineseNumber[] = {"一", "二", "三", "四", "五", "六", "七", "八", "九", "十", "十一", "十二"};
  12. static SimpleDateFormat chineseDateFormat = new SimpleDateFormat("yyyy年MM月dd日");
  13. final static long[] lunarInfo = new long[]
  14. {0x04bd8, 0x04ae0, 0x0a570, 0x054d5, 0x0d260, 0x0d950, 0x16554, 0x056a0, 0x09ad0, 0x055d2,
  15. 0x04ae0, 0x0a5b6, 0x0a4d0, 0x0d250, 0x1d255, 0x0b540, 0x0d6a0, 0x0ada2, 0x095b0, 0x14977,
  16. 0x04970, 0x0a4b0, 0x0b4b5, 0x06a50, 0x06d40, 0x1ab54, 0x02b60, 0x09570, 0x052f2, 0x04970,
  17. 0x06566, 0x0d4a0, 0x0ea50, 0x06e95, 0x05ad0, 0x02b60, 0x186e3, 0x092e0, 0x1c8d7, 0x0c950,
  18. 0x0d4a0, 0x1d8a6, 0x0b550, 0x056a0, 0x1a5b4, 0x025d0, 0x092d0, 0x0d2b2, 0x0a950, 0x0b557,
  19. 0x06ca0, 0x0b550, 0x15355, 0x04da0, 0x0a5d0, 0x14573, 0x052d0, 0x0a9a8, 0x0e950, 0x06aa0,
  20. 0x0aea6, 0x0ab50, 0x04b60, 0x0aae4, 0x0a570, 0x05260, 0x0f263, 0x0d950, 0x05b57, 0x056a0,
  21. 0x096d0, 0x04dd5, 0x04ad0, 0x0a4d0, 0x0d4d4, 0x0d250, 0x0d558, 0x0b540, 0x0b5a0, 0x195a6,
  22. 0x095b0, 0x049b0, 0x0a974, 0x0a4b0, 0x0b27a, 0x06a50, 0x06d40, 0x0af46, 0x0ab60, 0x09570,
  23. 0x04af5, 0x04970, 0x064b0, 0x074a3, 0x0ea50, 0x06b58, 0x055c0, 0x0ab60, 0x096d5, 0x092e0,
  24. 0x0c960, 0x0d954, 0x0d4a0, 0x0da50, 0x07552, 0x056a0, 0x0abb7, 0x025d0, 0x092d0, 0x0cab5,
  25. 0x0a950, 0x0b4a0, 0x0baa4, 0x0ad50, 0x055d9, 0x04ba0, 0x0a5b0, 0x15176, 0x052b0, 0x0a930,
  26. 0x07954, 0x06aa0, 0x0ad50, 0x05b52, 0x04b60, 0x0a6e6, 0x0a4e0, 0x0d260, 0x0ea65, 0x0d530,
  27. 0x05aa0, 0x076a3, 0x096d0, 0x04bd7, 0x04ad0, 0x0a4d0, 0x1d0b6, 0x0d250, 0x0d520, 0x0dd45,
  28. 0x0b5a0, 0x056d0, 0x055b2, 0x049b0, 0x0a577, 0x0a4b0, 0x0aa50, 0x1b255, 0x06d20, 0x0ada0};
  29. //====== 传回农历 y年的总天数
  30. final private static int yearDays(int y) {
  31. int i, sum = 348;
  32. for (i = 0x8000; i > 0x8; i >>= 1) {
  33. if ((lunarInfo[y - 1900] & i) != 0) sum += 1;
  34. }
  35. return (sum + leapDays(y));
  36. }
  37. //====== 传回农历 y年闰月的天数
  38. final private static int leapDays(int y) {
  39. if (leapMonth(y) != 0) {
  40. if ((lunarInfo[y - 1900] & 0x10000) != 0)
  41. return 30;
  42. else
  43. return 29;
  44. } else
  45. return 0;
  46. }
  47. //====== 传回农历 y年闰哪个月 1-12 , 没闰传回 0
  48. final private static int leapMonth(int y) {
  49. return (int) (lunarInfo[y - 1900] & 0xf);
  50. }
  51. //====== 传回农历 y年m月的总天数
  52. final private static int monthDays(int y, int m) {
  53. if ((lunarInfo[y - 1900] & (0x10000 >> m)) == 0)
  54. return 29;
  55. else
  56. return 30;
  57. }
  58. //====== 传回农历 y年的生肖
  59. final public String animalsYear() {
  60. final String[] Animals = new String[]{"鼠", "牛", "虎", "兔", "龙", "蛇", "马", "羊", "猴", "鸡", "狗", "猪"};
  61. return Animals[(year - 4) % 12];
  62. }
  63. //====== 传入 月日的offset 传回干支, 0=甲子
  64. final private static String cyclicalm(int num) {
  65. final String[] Gan = new String[]{"甲", "乙", "丙", "丁", "戊", "己", "庚", "辛", "壬", "癸"};
  66. final String[] Zhi = new String[]{"子", "丑", "寅", "卯", "辰", "巳", "午", "未", "申", "酉", "戌", "亥"};
  67. return (Gan[num % 10] + Zhi[num % 12]);
  68. }
  69. //====== 传入 offset 传回干支, 0=甲子
  70. final public String cyclical() {
  71. int num = year - 1900 + 36;
  72. return (cyclicalm(num));
  73. }
  74. /** *//**
  75. * 传出y年m月d日对应的农历.
  76. * yearCyl3:农历年与1864的相差数              ?
  77. * monCyl4:从1900年1月31日以来,闰月数
  78. * dayCyl5:与1900年1月31日相差的天数,再加40      ?
  79. * @param cal
  80. * @return
  81. */
  82. public Lunar(Calendar cal) {
  83. @SuppressWarnings("unused") int yearCyl, monCyl, dayCyl;
  84. int leapMonth = 0;
  85. Date baseDate = null;
  86. try {
  87. baseDate = chineseDateFormat.parse("1900年1月31日");
  88. } catch (ParseException e) {
  89. e.printStackTrace();  //To change body of catch statement use Options | File Templates.
  90. }
  91. //求出和1900年1月31日相差的天数
  92. int offset = (int) ((cal.getTime().getTime() - baseDate.getTime()) / 86400000L);
  93. dayCyl = offset + 40;
  94. monCyl = 14;
  95. //用offset减去每农历年的天数
  96. // 计算当天是农历第几天
  97. //i最终结果是农历的年份
  98. //offset是当年的第几天
  99. int iYear, daysOfYear = 0;
  100. for (iYear = 1900; iYear < 2050 && offset > 0; iYear++) {
  101. daysOfYear = yearDays(iYear);
  102. offset -= daysOfYear;
  103. monCyl += 12;
  104. }
  105. if (offset < 0) {
  106. offset += daysOfYear;
  107. iYear--;
  108. monCyl -= 12;
  109. }
  110. //农历年份
  111. year = iYear;
  112. yearCyl = iYear - 1864;
  113. leapMonth = leapMonth(iYear); //闰哪个月,1-12
  114. leap = false;
  115. //用当年的天数offset,逐个减去每月(农历)的天数,求出当天是本月的第几天
  116. int iMonth, daysOfMonth = 0;
  117. for (iMonth = 1; iMonth < 13 && offset > 0; iMonth++) {
  118. //闰月
  119. if (leapMonth > 0 && iMonth == (leapMonth + 1) && !leap) {
  120. --iMonth;
  121. leap = true;
  122. daysOfMonth = leapDays(year);
  123. } else
  124. daysOfMonth = monthDays(year, iMonth);
  125. offset -= daysOfMonth;
  126. //解除闰月
  127. if (leap && iMonth == (leapMonth + 1)) leap = false;
  128. if (!leap) monCyl++;
  129. }
  130. //offset为0时,并且刚才计算的月份是闰月,要校正
  131. if (offset == 0 && leapMonth > 0 && iMonth == leapMonth + 1) {
  132. if (leap) {
  133. leap = false;
  134. } else {
  135. leap = true;
  136. --iMonth;
  137. --monCyl;
  138. }
  139. }
  140. //offset小于0时,也要校正
  141. if (offset < 0) {
  142. offset += daysOfMonth;
  143. --iMonth;
  144. --monCyl;
  145. }
  146. month = iMonth;
  147. day = offset + 1;
  148. }
  149. public static String getChinaDayString(int day) {
  150. String chineseTen[] = {"初", "十", "廿", "卅"};
  151. int n = day % 10 == 0 ? 9 : day % 10 - 1;
  152. if (day > 30)
  153. return "";
  154. if (day == 10)
  155. return "初十";
  156. else
  157. return chineseTen[day / 10] + chineseNumber[n];
  158. }
  159. public String toString() {
  160. return year + "年" + (leap ? "闰" : "") + chineseNumber[month - 1] + "月" + getChinaDayString(day);
  161. }
  162. public static void main(String[] args) throws ParseException {
  163. Calendar today = Calendar.getInstance();
  164. today.setTime(chineseDateFormat.parse("2003年1月1日"));
  165. Lunar lunar = new Lunar(today);
  166. System.out.println("北京时间:" + chineseDateFormat.format(today.getTime()) + " 农历" + lunar);
  167. }
  168. }

java,阳历转阴历(农历)相关推荐

  1. php阳历转阴历(农历),阴历转阳历的方法

    2019独角兽企业重金招聘Python工程师标准>>> <?php header ( "Content-Type: text/html; charset=utf-8& ...

  2. java阳历转为阴历错了一天_Java 阴历阳历转换

    代码如下 收藏备用 import java.util.Arrays; import java.util.Date; import java.util.GregorianCalendar; /** * ...

  3. 阳历、阴历、干支历转换 - For JAVA

    历法计算,可实现阳历.阴历.干支历的相互转换 一个可实现阳历.阴历.干支历间相互转换的JAVA工具 项目Github地址: https://github.com/opprime/calendarist ...

  4. java阳历农历互相转换

    package fhj.help; import java.text.ParseException; import java.text.SimpleDateFormat; import java.ut ...

  5. PHP实现阳历(新历)与阴历(农历)互相转换

    使用方法: <?php header("Content-Type:text/html;charset=utf-8"); require "lunar.php&quo ...

  6. python公历转农历_python 阳历转阴历代码(2)

    main.py #!/usr/bin/env python # -*- coding: utf-8 -*- #给出阳历日期转换成阴历日期 import math from daysbetween im ...

  7. JavaScript之js-calendar-converter插件的使用、日历、日期、转换、阳历、阴历、公历、农历、calendar

    文章目录 前言 下载js-calendar-converter插件 插件介绍 查询属性表 获取的方法 转换的方法 设置的方法 微信小程序查看效果 日历选择案例 前言 在做算命项目时遇到公历和农历相互转 ...

  8. PB中公历与农历(阳历与阴历)的互相转换——主要是农历转公历(阴历转阳历)

    PB中关于公历转农历的算法,网上有很多,思路也大致一样,在这里我就不再进行说明了. 本文主要是想跟所有PB爱好者,分享农历转公历的方法. 转换思路为:根据传入的农历日期,找到第一个小于传入日期的基准日 ...

  9. 阴历转阳历java_GitHub - opprime/calendarist: 一个可实现阳历、阴历、干支历间相互转换的JAVA工具...

    历法计算家,可实现阳历.阴历.干支历的相互转换 使用方法 Maven引用 org.hothub calendarist 1.0.7 功能介绍 支持1900 - 2100年份的日期转换 支持阳历日期转阴 ...

最新文章

  1. 判断二叉树是否为平衡二叉树
  2. SpringtMVC中配置 mvc:annotation-driven/ 与 mvc:default-servlet-handler/ 的作用
  3. 什么是JAVA语言为什么要学习JAVA
  4. Oracle 排序中使用nulls first 或者nulls last 语法
  5. 解决spring的bean同名冲突
  6. 一文简述FFmpeg
  7. .NET Core IdentityServer4实战 第六章-Consent授权页
  8. linux 修复图形界面,图形界面操作的备份和恢复Linux发行版
  9. scala.list
  10. python之format函数学习
  11. NumPy学习笔记之argsort()函数
  12. 安全体系(三)——SHA1算法详解
  13. html5 input step,HTML5 Data Input 元素介绍
  14. java.lang.exceptionininitializererror_java.lang.ExceptionInInitializerError异常的解决方法
  15. 收款码在线生成系统源码 无限制
  16. Preparatory Class-Day8------函数
  17. [2021 蓝帽杯]杰克与肉丝
  18. 程序员好几年才能成为架构师_成为更好的企业架构师
  19. 工商管理专业知识与实务(初级)【8】
  20. 高考数学题目:导数及其简单应用

热门文章

  1. 第一个项目(奶茶APP)
  2. c++动态规划经典算例
  3. 解决虚拟机Linux获取不到ip或者登陆地址tty1获取不到ip方法
  4. php 云监工,玩客云综合工具下载
  5. 手把手教你用python一键抢12306火车票(附代码)
  6. linux的socket模型有哪些,异步io 编程 Linux Socket五种I/O模型(zhuan(3)
  7. 重定向和转发技术的使用场景
  8. Python数据分析案例03——天气K均值聚类分析
  9. Google博客(BlogSpot)打不开的解决方法
  10. php中求解二元一次方程,二元一次方程组及其解法(第1课时)