农历天干地支算法源代码大全(javascript、vbscript、C#、flash、C++、C等等)

农历天干地支算法源代码大全
(javascript、vbscript、C#、flash、C++、C等等)

WonSoft编

文章提供计算农历天干地支及当年属相的算法源程序,使用的语言为Javascript、VBScript、C#等。

一、C# 代码(1):

原来还准备自己写算法,并研究农历规则。发现那太难和麻烦了,光是农历的推算那就我等专门研究历法的人一下搞懂的。后来发现。NET类库也提供一些基础的农历类System.Globalization.ChineseLunisolarCalendar。我改装了一下如DateTime时间形式。代码如下。实现了 公历农历转换的功能。但是只能算到1900~2100年之间的。基本够日常使用了。源代码如下:

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Text;
  4. namespace System
  5. {
  6.    //// 
  7.     /// 中国常用农历日期时间类
  8.     /// [email protected]   http://hi.csdn.net/zj53hao
  9.     /// 
  10.     class ChinaDateTime
  11.     {
  12.         private int year, month, dayOfMonth;
  13.         private bool isLeap;
  14.         public DateTime time;
  15.         //// 
  16.         /// 获取当前日期的农历年
  17.         /// 
  18.         public int Year
  19.         {
  20.             get { return year; }
  21.         }
  22.         //// 
  23.         /// 获取当前日期的农历月份
  24.         /// 
  25.         public int Month
  26.         {
  27.             get { return month; }
  28.         }
  29.         //// 
  30.         /// 获取当前日期的农历月中天数
  31.         /// 
  32.         public int DayOfMonth
  33.         {
  34.             get { return dayOfMonth; }
  35.         }
  36.         //// 
  37.         /// 获取当前日期是否为闰月中的日期
  38.         /// 
  39.         public bool IsLeap
  40.         {
  41.             get { return isLeap; }
  42.         }
  43.         System.Globalization.ChineseLunisolarCalendar cc;
  44.         //// 
  45.         /// 返回指定公历日期的阴历时间
  46.         /// 
  47.         /// 
  48.         public ChinaDateTime(DateTime time)
  49.         {
  50.             cc = new System.Globalization.ChineseLunisolarCalendar();
  51.             
  52.              if (time > cc.MaxSupportedDateTime || time < cc.MinSupportedDateTime)
  53.                 throw new Exception("参数日期时间不在支持的范围内,支持范围:" + cc.MinSupportedDateTime.ToShortDateString()+"到"+cc.MaxSupportedDateTime.ToShortDateString());
  54.             year = cc.GetYear(time);
  55.             month = cc.GetMonth(time);
  56.             dayOfMonth = cc.GetDayOfMonth(time);
  57.             isLeap = cc.IsLeapMonth(year, month);
  58.             if (isLeap) month -= 1;
  59.             this.time = time;
  60.         }
  61.         //// 
  62.         /// 返回当前日前的农历日期。
  63.         /// 
  64.         public static ChinaDateTime Now
  65.         {
  66.             get { return new ChinaDateTime(DateTime.Now); }
  67.         }
  68.         //// 
  69.         /// 返回指定农历年,月,日,是否为闰月的农历日期时间
  70.         /// 
  71.         /// 
  72.         /// 
  73.         /// 
  74.         /// 
  75.         public ChinaDateTime(int Year, int Month, int DayOfMonth, bool IsLeap)
  76.         {
  77.             if (Year >= cc.MaxSupportedDateTime.Year || Year <= cc.MinSupportedDateTime.Year)
  78.                 throw new Exception("参数年份时间不在支持的范围内,支持范围:" + cc.MinSupportedDateTime.ToShortDateString() + "到" + cc.MaxSupportedDateTime.ToShortDateString());
  79.             if (Month < 1 || Month > 12)
  80.                 throw new Exception("月份必须在1~12范围");
  81.             cc = new System.Globalization.ChineseLunisolarCalendar();
  82.             
  83.             if(cc.GetLeapMonth(Year)!=Month&&IsLeap)
  84.                 throw new Exception("指定的月份不是当年的闰月");
  85.             if (cc.GetDaysInMonth(Year, IsLeap ? Month + 1 : Month) < DayOfMonth || DayOfMonth < 1)
  86.                 throw new Exception("指定的月中的天数不在当前月天数有效范围");
  87.             year = Year;
  88.             month = Month;
  89.             dayOfMonth = DayOfMonth;
  90.             isLeap = IsLeap;
  91.             time = DateTime.Now;
  92.         }
  93.         //// 
  94.         /// 获取当前农历日期的公历时间
  95.         /// 
  96.         public DateTime ToDateTime()
  97.         {
  98.             return cc.ToDateTime(year, isLeap ? month + 1 : month, dayOfMonth, time.Hour, time.Minute, time.Second, time.Millisecond);
  99.         }
  100.         //// 
  101.         /// 获取指定农历时间对应的公历时间
  102.         /// 
  103.         /// 
  104.         /// 
  105.         public static DateTime ToDateTime(ChinaDateTime CnTime)
  106.         {
  107.             return CnTime.ToDateTime();
  108.         }
  109.         //// 
  110.         /// 获取指定公历时间转换为农历时间
  111.         /// 
  112.         /// 
  113.         /// 
  114.         public static ChinaDateTime ToChinaDateTime(DateTime Time)
  115.         {
  116.             return new ChinaDateTime(Time);
  117.         }     
  118.    }
  119. }

二、C#代码(2):

1、农历类的使用

.net框架不支持直接将日期转换成农历格式的字符串,那么要将显示农历格式的日期,就只要自已写代码了。不过由于已经有了ChineseLunisolarCalendar类实现了公历转换为农历日期的功能,所以要写这样的代码也比较简单。需要用到ChineseLunisolarCalendar以下几个主要方法:

int GetYear (DateTime time) 获取指定公历日期的农历年份,使用的还是公历纪元。在每年的元旦之后春节之前农历的纪年会比公历小1,其它时候等于公历纪年。虽然农历使用传说中的耶稣生日纪元似乎不太妥当,不过我们确实已经几十年没有实行一个更好的纪年办法,也只有将就了。

int GetMonth (DateTime time) 获取指定公历日期的农历月份。这里要注意了,由于农历有接近三分之一的年份存在闰月,则在这些年份里会有十三个,而具体哪一个月是闰月也说不准,这里不同于希伯来历。以今年为例,今年闰七月,则此方法在参数为闰七月的日期是返回值为 8,参数为农历十二月的日期时返回值为13

bool IsLeapMonth ( int year,   int month) 获取指定农历年份和月份是否为闰月,这个函数和上个函数配合使用就可以算出农历的月份了。

int GetDayOfMonth (DateTime time) 获取指定公历日期的农历天数,这个值根据大月或者小月取值是1到30或者1到29, MSDN上说的1到31显然是错的, 没有哪个农历月份会有31天。

int GetSexagenaryYear (DateTime time) 获取指定公历日期的农历年份的干支纪年,从1到60,分别是甲子、乙丑、丙寅、….癸亥, 比如戊戌变法、辛亥革命就是按这个来命名的。当然算八字也少不了这个。

int GetCelestialStem (int sexagenaryYear) 获取一个天支的天干, 从1到10, 表示甲、乙、丙….,说白了就是对10取模。

int GetTerrestrialBranch (int sexagenaryYear) ) 获取一个干支的地支,, 从1到12, 表示子、丑、寅、…今年是狗年,那么今年年份的地支就是“戌”。

有了这几个方法,显示某天的农历月份日期、农历节日等都是小菜一碟,算命先生排八字用这几个方法,又快又准确,写出的代码也很短。

2、几种东亚农历类的区别

经过我的测试,ChineseLunisolarCalendar, JapaneseLunisolarCalendar, KoreanLunisolaCalendarr, TaiwanLunisolarCalendar这四种日历,无论哪一种,以200626日为参数,调用它们的GetMonth方法得到的结果都是1GetDayOfMonth得到的结果都是8。想想也是,我们过的端午节和韩国的不太可能不是一天。

但是调用GetYear方法得到结果就有区别了ChineseLunisolarCalendarKoreanLunisolarCalendar都返回2006,也就是公历纪年,TaiwanLunisolarCalendar的返回值是95,依然是民国纪年,JapaneseLunisolarCalendar的返回值是18, 平成纪年。

另外的一个区别是这四种日历的MinSupportedDateTimeMaxSupportedDateTime各不一样,以下是对照表:

日历类 MinSupportedDateTime MaxSupportedDateTime
ChineseLunisolarCalendar 公元19011月初1 公元21001229
TaiwanLunisolarCalendar 民国11月初1 民国1391229
JapaneseLunisolarCalendar 昭和351月初1 平成611229
KoreanLunisolarCalendar 公元9181月初1 公元20501229

韩国农历类支持的最小日期为918(也即高丽王朝建立的年份),以此而论,中国农历类支持的最小日期不说从商周算起,从汉唐算总该没问题吧?微软公司啊,又在“厚彼薄此”,唉。

其次,日本还以天皇纪年,如果哪天xxxx, 岂不是使用JapaneseLunisolarCalendar写出的程序都有问题啦?

3、写自已的日期格式化器

昨天看了一篇文章,说目前大家用的“农历”这个术语是文革时期才有的,目的是反封建。这里为了省事,还是继续使用这个术语。而英文名称ChineseLunisolarCalendar太长,我自己的代码中就用ChineseCalendar为相关功能命名,这个名字也还过得去吧。

我原先设想自定义一个类,使得能写出这样的代码:
string s= DateTime.Now.ToString(new MyFormatProvider());
就能得出我想要的农历日期字符串,经过测试却失败了,依据我的分析,微软公司在.net框架中把日期时间型的格式写死了,只能依据相关的地区采用固定的几种显示格式,没法再自行定义。而前文已经说过,而所有的相关格式微软公司都放到一个名为culture.nlp的文件中(这个文件在以前的.net框架是一个独立的文件,在.net 2.0被作为一个资源编译到mscorlib.dll中。) (我的这个不能为DateTime写自已的格式化器的观点没有资料佐证,如有不当之处,请大家指正)

虽然不能为DataTime写自定义的格式器,但还有另外一个途径,就是为String类的Format方法写自定义格式化器,我测试了一下,效果还不错,调用方式如下:

string s= String.Format(new ChineseCalendarFormatter(), "{0:D}",DateTime.Now);
可以得到“二〇〇六年正月初九”
string s= String.Format(new ChineseCalendarFormatter(), "{0:d}",DateTime.Now);
可以得到“丙戌年正月初九”

虽然没有前面所设想的方便,但也还能接受,全部代码帖出如下:
第一个类,主要是封装了农历的一些常用字符和对日历处理的最基本功能

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Text;
  4. using System.Globalization;
  5. public static class ChineseCalendarHelper
  6. {
  7.     public static string GetYear(DateTime time)
  8.     {
  9.         StringBuilder sb = new StringBuilder();
  10.         int year = calendar.GetYear(time);
  11.         int d;
  12.         do
  13.         {
  14.             d = year % 10;
  15.             sb.Insert(0, ChineseNumber[d]);
  16.             year = year / 10;
  17.         } while (year > 0);
  18.         return sb.ToString();
  19.     }
  20.     public static string GetMonth(DateTime time)
  21.     {
  22.         int month = calendar.GetMonth(time);
  23.         int year = calendar.GetYear(time);
  24.         int leap = 0;
  25.         //正月不可能闰月
  26.         for (int i = 3; i <= month; i++)
  27.         {
  28.             if (calendar.IsLeapMonth(year, i))
  29.             {
  30.                 leap = i;
  31.                 break;  //一年中最多有一个闰月
  32.             }
  33.         }
  34.         if (leap > 0) month--;
  35.         return (leap == month + 1 ? "闰" : "") + ChineseMonthName[month - 1];
  36.     }
  37.     public static string GetDay(DateTime time)
  38.     {
  39.         return ChineseDayName[calendar.GetDayOfMonth(time) - 1];
  40.     }
  41.     public static string GetStemBranch(DateTime time)
  42.     {
  43.         int sexagenaryYear = calendar.GetSexagenaryYear(time);
  44.         string stemBranch = CelestialStem.Substring(sexagenaryYear % 10 - 1, 1) + 
  45.                       TerrestrialBranch.Substring(sexagenaryYear % 12 - 1, 1);
  46.         return stemBranch;
  47.     }
  48.     private static ChineseLunisolarCalendar calendar = new ChineseLunisolarCalendar();
  49.     private static string ChineseNumber = "〇一二三四五六七八九";
  50.     public const string CelestialStem = "甲乙丙丁戊己庚辛壬癸";
  51.     public const string TerrestrialBranch = "子丑寅卯辰巳午未申酉戌亥";
  52.     public static readonly string[] ChineseDayName = new string[] {
  53.             "初一","初二","初三","初四","初五","初六","初七","初八","初九","初十",
  54.             "十一","十二","十三","十四","十五","十六","十七","十八","十九","二十",
  55.             "廿一","廿二","廿三","廿四","廿五","廿六","廿七","廿八","廿九","三十"};
  56.     public static readonly string[] ChineseMonthName = new string[] 
  57.            { "正""二""三""四""五""六""七""八""九""十""十一""十二" };
  58. }

第二个类为自定义格式化器:

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Text;
  4. using System.Globalization;
  5. using System.Threading;
  6. public class ChineseCalendarFormatter : IFormatProvider, ICustomFormatter
  7. {
  8.     //实现IFormatProvider
  9.     public object GetFormat(Type formatType)
  10.     {
  11.         if (formatType == typeof(ICustomFormatter))
  12.             return this;
  13.         else
  14.             return Thread.CurrentThread.CurrentCulture.GetFormat(formatType);
  15.     }
  16.     //实现ICustomFormatter
  17.     public string Format(string format, object arg, IFormatProvider formatProvider)
  18.     {
  19.         string s;
  20.         IFormattable formattable = arg as IFormattable;
  21.         if (formattable == null)
  22.             s = arg.ToString();
  23.         else
  24.             s = formattable.ToString(format, formatProvider);
  25.         if (arg.GetType() == typeof(DateTime))
  26.         {
  27.             DateTime time = (DateTime)arg;
  28.             switch (format)
  29.             {
  30.                 case "D"//长日期格式
  31.                     s = String.Format("{0}年{1}月{2}",
  32.                         ChineseCalendarHelper.GetYear(time),
  33.                         ChineseCalendarHelper.GetMonth(time),
  34.                         ChineseCalendarHelper.GetDay(time));
  35.                     break;
  36.                 case "d"//短日期格式
  37.                     s = String.Format("{0}年{1}月{2}", ChineseCalendarHelper.GetStemBranch(time),
  38.                         ChineseCalendarHelper.GetMonth(time),
  39.                         ChineseCalendarHelper.GetDay(time));
  40.                     break;
  41.                 case "M"//月日格式
  42.                     s = String.Format("{0}月{1}", ChineseCalendarHelper.GetMonth(time),
  43.                         ChineseCalendarHelper.GetDay(time));
  44.                     break;
  45.                 case "Y"//年月格式
  46.                     s = String.Format("{0}年{1}月", ChineseCalendarHelper.GetYear(time),
  47.                         ChineseCalendarHelper.GetMonth(time));
  48.                     break;
  49.                 default:
  50.                     s = String.Format("{0}年{1}月{2}", ChineseCalendarHelper.GetYear(time),
  51.                         ChineseCalendarHelper.GetMonth(time),
  52.                         ChineseCalendarHelper.GetDay(time));
  53.                     break;
  54.             }
  55.         }
  56.         return s;
  57.     }
  58. }

这段代码中间处理格式那部份稍做改进,就可以支持更多的日期格式。

有了这两段代码为原型,要实现计算和显示一个日期的农历日期及其它功能,基本上就很容易了。

三、VBScript 代码

  1. <%
  2. 'Wonsoft, Welcome to visit my web http://wonsoft.cn
  3. '***********************************************
  4. ' 类名称:ChinaDay
  5. ' 用途:
  6. ' 根据输入的日期计算该日期的农历天干地支及当年属相
  7. ' 使用方法:
  8. ' 第一个参数为输入参数,不填写默认为当日,
  9. ' 只计算1921-2-8之后的日期
  10. ' ##-------------------------------------------##
  11. ' Dim objChinaDay 
  12. ' Dim sDay, sWeekDay, sChinaDay, sChinaYear,sChinaAni
  13. ' Set objChinaDay = New ChinaDay
  14. ' Call objChinaDay.Action("",sDay,sWeekDay,sChinaYear,sChinaDay,sChinaAni)
  15. ' Response.Write sDay&"<BR>"
  16. ' Response.Write sWeekDay&"<BR>"
  17. ' Response.Write sChinaYear&"<BR>"
  18. ' Response.Write sChinaDay&"<BR>"
  19. ' Response.Write sChinaAni&"<BR>"
  20. ' ##-------------------------------------------##
  21. ' Copyright: 本代码非原创,是2001年收集的,原作者未知。
  22. ' License:Free
  23. '*******************************************************
  24. Class ChinaDay
  25. Dim arrWeekName(7), MonthAdd(11), NongliData(99)
  26. Dim arrTianGan(9), arrDiZhi(11), arrShuXiang(11), arrDayName(30), arrMonName(12)
  27. Dim curTime, curYear, curMonth, curDay, curWeekday
  28. Dim i, m, n, k, isEnd, bit, TheDate
  29. '初始化数据
  30. Sub Class_Initialize()
  31. '---------------------------------------------------
  32. '定义显示字串
  33. '星期名
  34. arrWeekName(0) = "*"
  35. arrWeekName(1) = "星期日"
  36. arrWeekName(2) = "星期一"
  37. arrWeekName(3) = "星期二"
  38. arrWeekName(4) = "星期三"
  39. arrWeekName(5) = "星期四"
  40. arrWeekName(6) = "星期五"
  41. arrWeekName(7) = "星期六"
  42. '天干名称
  43. arrTianGan(0) = "甲"
  44. arrTianGan(1) = "乙"
  45. arrTianGan(2) = "丙"
  46. arrTianGan(3) = "丁"
  47. arrTianGan(4) = "戊"
  48. arrTianGan(5) = "己"
  49. arrTianGan(6) = "庚"
  50. arrTianGan(7) = "辛"
  51. arrTianGan(8) = "壬"
  52. arrTianGan(9) = "癸"
  53. '地支名称
  54. arrDiZhi(0) = "子"
  55. arrDiZhi(1) = "丑"
  56. arrDiZhi(2) = "寅"
  57. arrDiZhi(3) = "卯"
  58. arrDiZhi(4) = "辰"
  59. arrDiZhi(5) = "巳"
  60. arrDiZhi(6) = "午"
  61. arrDiZhi(7) = "未"
  62. arrDiZhi(8) = "申"
  63. arrDiZhi(9) = "酉"
  64. arrDiZhi(10) = "戌"
  65. arrDiZhi(11) = "亥"
  66. '属相名称
  67. arrShuXiang(0) = "鼠"
  68. arrShuXiang(1) = "牛"
  69. arrShuXiang(2) = "虎"
  70. arrShuXiang(3) = "兔"
  71. arrShuXiang(4) = "龙"
  72. arrShuXiang(5) = "蛇"
  73. arrShuXiang(6) = "马"
  74. arrShuXiang(7) = "羊"
  75. arrShuXiang(8) = "猴"
  76. arrShuXiang(9) = "鸡"
  77. arrShuXiang(10) = "狗"
  78. arrShuXiang(11) = "猪"
  79. '农历日期名
  80. arrDayName(0) = "*"
  81. arrDayName(1) = "初一"
  82. arrDayName(2) = "初二"
  83. arrDayName(3) = "初三"
  84. arrDayName(4) = "初四"
  85. arrDayName(5) = "初五"
  86. arrDayName(6) = "初六"
  87. arrDayName(7) = "初七"
  88. arrDayName(8) = "初八"
  89. arrDayName(9) = "初九"
  90. arrDayName(10) = "初十"
  91. arrDayName(11) = "十一"
  92. arrDayName(12) = "十二"
  93. arrDayName(13) = "十三"
  94. arrDayName(14) = "十四"
  95. arrDayName(15) = "十五"
  96. arrDayName(16) = "十六"
  97. arrDayName(17) = "十七"
  98. arrDayName(18) = "十八"
  99. arrDayName(19) = "十九"
  100. arrDayName(20) = "二十"
  101. arrDayName(21) = "廿一"
  102. arrDayName(22) = "廿二"
  103. arrDayName(23) = "廿三"
  104. arrDayName(24) = "廿四"
  105. arrDayName(25) = "廿五"
  106. arrDayName(26) = "廿六"
  107. arrDayName(27) = "廿七"
  108. arrDayName(28) = "廿八"
  109. arrDayName(29) = "廿九"
  110. arrDayName(30) = "三十"
  111. '农历月份名
  112. arrMonName(0) = "*"
  113. arrMonName(1) = "正"
  114. arrMonName(2) = "二"
  115. arrMonName(3) = "三"
  116. arrMonName(4) = "四"
  117. arrMonName(5) = "五"
  118. arrMonName(6) = "六"
  119. arrMonName(7) = "七"
  120. arrMonName(8) = "八"
  121. arrMonName(9) = "九"
  122. arrMonName(10) = "十"
  123. arrMonName(11) = "十一"
  124. arrMonName(12) = "腊"
  125. '---------------------------------------------------------
  126. '公差数据定义
  127. '公历每月前面的天数
  128. MonthAdd(0) = 0
  129. MonthAdd(1) = 31
  130. MonthAdd(2) = 59
  131. MonthAdd(3) = 90
  132. MonthAdd(4) = 120
  133. MonthAdd(5) = 151
  134. MonthAdd(6) = 181
  135. MonthAdd(7) = 212
  136. MonthAdd(8) = 243
  137. MonthAdd(9) = 273
  138. MonthAdd(10) = 304
  139. MonthAdd(11) = 334
  140. '农历数据
  141. NongliData(0) = 2635
  142. NongliData(1) = 333387
  143. NongliData(2) = 1701
  144. NongliData(3) = 1748
  145. NongliData(4) = 267701
  146. NongliData(5) = 694
  147. NongliData(6) = 2391
  148. NongliData(7) = 133423
  149. NongliData(8) = 1175
  150. NongliData(9) = 396438
  151. NongliData(10) = 3402
  152. NongliData(11) = 3749
  153. NongliData(12) = 331177
  154. NongliData(13) = 1453
  155. NongliData(14) = 694
  156. NongliData(15) = 201326
  157. NongliData(16) = 2350
  158. NongliData(17) = 465197
  159. NongliData(18) = 3221
  160. NongliData(19) = 3402
  161. NongliData(20) = 400202
  162. NongliData(21) = 2901
  163. NongliData(22) = 1386
  164. NongliData(23) = 267611
  165. NongliData(24) = 605
  166. NongliData(25) = 2349
  167. NongliData(26) = 137515
  168. NongliData(27) = 2709
  169. NongliData(28) = 464533
  170. NongliData(29) = 1738
  171. NongliData(30) = 2901
  172. NongliData(31) = 330421
  173. NongliData(32) = 1242
  174. NongliData(33) = 2651
  175. NongliData(34) = 199255
  176. NongliData(35) = 1323
  177. NongliData(36) = 529706
  178. NongliData(37) = 3733
  179. NongliData(38) = 1706
  180. NongliData(39) = 398762
  181. NongliData(40) = 2741
  182. NongliData(41) = 1206
  183. NongliData(42) = 267438
  184. NongliData(43) = 2647
  185. NongliData(44) = 1318
  186. NongliData(45) = 204070
  187. NongliData(46) = 3477
  188. NongliData(47) = 461653
  189. NongliData(48) = 1386
  190. NongliData(49) = 2413
  191. NongliData(50) = 330077
  192. NongliData(51) = 1197
  193. NongliData(52) = 2637
  194. NongliData(53) = 268877
  195. NongliData(54) = 3365
  196. NongliData(55) = 531109
  197. NongliData(56) = 2900
  198. NongliData(57) = 2922
  199. NongliData(58) = 398042
  200. NongliData(59) = 2395
  201. NongliData(60) = 1179
  202. NongliData(61) = 267415
  203. NongliData(62) = 2635
  204. NongliData(63) = 661067
  205. NongliData(64) = 1701
  206. NongliData(65) = 1748
  207. NongliData(66) = 398772
  208. NongliData(67) = 2742
  209. NongliData(68) = 2391
  210. NongliData(69) = 330031
  211. NongliData(70) = 1175
  212. NongliData(71) = 1611
  213. NongliData(72) = 200010
  214. NongliData(73) = 3749
  215. NongliData(74) = 527717
  216. NongliData(75) = 1452
  217. NongliData(76) = 2742
  218. NongliData(77) = 332397
  219. NongliData(78) = 2350
  220. NongliData(79) = 3222
  221. NongliData(80) = 268949
  222. NongliData(81) = 3402
  223. NongliData(82) = 3493
  224. NongliData(83) = 133973
  225. NongliData(84) = 1386
  226. NongliData(85) = 464219
  227. NongliData(86) = 605
  228. NongliData(87) = 2349
  229. NongliData(88) = 334123
  230. NongliData(89) = 2709
  231. NongliData(90) = 2890
  232. NongliData(91) = 267946
  233. NongliData(92) = 2773
  234. NongliData(93) = 592565
  235. NongliData(94) = 1210
  236. NongliData(95) = 2651
  237. NongliData(96) = 395863
  238. NongliData(97) = 1323
  239. NongliData(98) = 2707
  240. NongliData(99) = 265877
  241. End Sub
  242. '############################################################
  243. '主要方法 Action
  244. ' inDay 输入日期,如果不输入则默认为当前日期
  245. ' sDay 中文格式日期
  246. ' sWeekDay 周几
  247. ' sChinaYear 农历年
  248. ' sChinaDay 农历日
  249. ' sChinaAni 属相
  250. '############################################################
  251. Public Function Action(inDay,sDay,sWeekDay,sChinaYear,sChinaDay,sChinaAni)
  252. '转换要转换的日期
  253. If inDay="" Or Not IsDate(inDay) Then
  254. '获取当前系统时间
  255. curTime = Now()
  256. Else
  257. curTime = CDate(inDay)
  258. End If
  259. If Datediff("d",curTime,Cdate("1921-2-8"))>0 Then
  260. Exit Function
  261. End If
  262. '生成当前公历年、月、日 ==> sDay
  263. curYear = Year(curTime)
  264. curMonth = Month(curTime)
  265. curDay = Day(curTime)
  266. sDay = curYear&"年"
  267. If (curMonth < 10) Then
  268. sDaysDay = sDay&"0"&curMonth&"月"
  269. Else
  270. sDaysDay = sDay&curMonth&"月"
  271. End If
  272. If (curDay < 10) Then
  273. sDaysDay = sDay&"0"&curDay&"日"
  274. Else
  275. sDaysDay = sDay&curDay&"日"
  276. End If 
  277. '生成当前公历星期 ==> sWeekDay
  278. curWeekday = Weekday(curTime)
  279. sWeekDay = arrWeekName(curWeekday)
  280. '计算到初始时间1921年2月8日的天数:1921-2-8(正月初一)
  281. TheDate = (curYear - 1921) * 365 + Int((curYear - 1921) / 4) + curDay + MonthAdd(curMonth - 1) - 38
  282. If ((curYear Mod 4) = 0 AND curMonth > 2) Then
  283. TheDateTheDate = TheDate + 1
  284. End If
  285. '计算农历天干、地支、月、日
  286. isEnd = 0
  287. m = 0
  288. '------------------------------------
  289. Do
  290. If (NongliData(m) < 4095) Then
  291. k = 11
  292. Else
  293. k = 12
  294. End if
  295. n = k
  296. '------------------------------------
  297. Do
  298. If (n < 0) Then
  299. Exit Do
  300. End If
  301. '获取NongliData(m)的第n个二进制位的值
  302. bit = NongliData(m)
  303. For i = 1 To n Step 1
  304. bit = Int(bit / 2)
  305. Next
  306. bitbit = bit Mod 2
  307. If (TheDate <= 29 + bit) Then
  308. isEnd = 1
  309. Exit Do
  310. End If
  311. TheDateTheDate = TheDate - 29 - bit
  312. nn = n - 1
  313. Loop
  314. '------------------------------------
  315. If (isEnd = 1) Then
  316. Exit Do
  317. End If
  318. mm = m + 1
  319. Loop
  320. '------------------------------------
  321. curYear = 1921 + m
  322. curMonth = k - n + 1
  323. curDay = TheDate
  324. If (k = 12) Then
  325. If (curMonth = (Int(NongliData(m) / 65536) + 1)) Then
  326. curMonth = 1 - curMonth
  327. ElseIf (curMonth > (Int(NongliData(m) / 65536) + 1)) Then
  328. curMonthcurMonth = curMonth - 1
  329. End if 
  330. End If
  331. '生成农历天干、地支==> sChinaYear
  332. sChinaYear = "农历"&arrTianGan(((curYear - 4) Mod 60) Mod 10)&arrDiZhi(((curYear - 4) Mod 60) Mod 12)&"年"
  333. '生成属相 == > sChinaAni
  334. sChinaAni = arrShuXiang(((curYear - 4) Mod 60) Mod 12)
  335. '生成农历月、日 ==> NongliDayStr
  336. If (curMonth < 1) Then
  337. sChinaDay = "闰"&arrMonName(-1 * curMonth)
  338. Else
  339. sChinaDay = arrMonName(curMonth)
  340. End If
  341. sChinaDaysChinaDay = sChinaDay&"月"
  342. sChinaDaysChinaDay = sChinaDay & arrDayName(curDay)
  343. End Function
  344. End Class
  345. %>

四、JavaScript 代码

  1. <SCRIPT language=JavaScript>

上面的代码不支持Firefox,请使用查找、替换,把getYear()修改为getFullYear()就可以支持firefox了。

五、Flash代码:

农历FLASH源码、旧历FLASH日历、旧历FLASH时钟
在FLASH中,制作时钟、日历都不难。在网上搜索一下,也会有一大遍源码等着你去下载。但不知是我孤陋寡闻,还是咋地。在网上还没见过农历的代码,在民族文化如此繁荣的中国。竟然没有人来研究这个。实在是有点遗憾。花点时间,研究了一下。随后把源码附上。希望大家共同讨论。其中难的就是闰月部分。

           点击播放/隐藏媒体:http://www.taoshaw.com/taoshaw/study/jilishizhong/Taoshaw_Time.swf

制作过程,前面的就不说了。直接发代码吧。
新建一倒计时类"Taoshaw_data.as"。
然后输入如下代码:

  1. class Taoshaw_data extends Date {
  2.   //================版权声明开始================//
  3.   //★淘沙网:http://www.taoshaw.com
  4.   //★淘沙网所有教程欢迎转载。不过请转载时注明出处。谢谢合作。
  5.   //================版权声明结束================//
  6.   /*=============================================
  7.    公元1900-2100两百年的农历类。
  8.    类的调用方法说明
  9.    getFullYear();获取新历年份
  10.    getnewMonth();获取月份
  11.    getDate()获取多少号.
  12.    getSeconds();获取秒值
  13.    getDay();获取星期几
  14.    getHours();获取小时(整点)
  15.    getMinutes();获取分数
  16.    getTaosJYear();获取中国农历年.
  17.    getTaoJMonth(); 获取中国农历月.
  18.    getTaoJDay();获取中国农历日.
  19.    getTaoJNianZhu();获取年柱
  20.    getYueZhu();获取月柱
  21.    getRiZhu();获取日柱
  22.    getShiceng();获取时辰
  23.    getJieQi();获取二十四节气
  24.    =============================================*/
  25.   private var tao_txtnum_info = new Array(0x4bd8, 0x4ae0, 0xa570, 0x54d5, 0xd260, 0xd950, 0x5554, 0x56af, 0x9ad0, 0x55d2, 0x4ae0, 0xa5b6, 0xa4d0, 0xd250, 0xd255, 0xb54f, 0xd6a0, 0xada2, 0x95b0, 0x4977, 0x497f, 0xa4b0, 0xb4b5, 0x6a50, 0x6d40, 0xab54, 0x2b6f, 0x9570, 0x52f2, 0x4970, 0x6566, 0xd4a0, 0xea50, 0x6a95, 0x5adf, 0x2b60, 0x86e3, 0x92ef, 0xc8d7, 0xc95f, 0xd4a0, 0xd8a6, 0xb55f, 0x56a0, 0xa5b4, 0x25df, 0x92d0, 0xd2b2, 0xa950, 0xb557, 0x6ca0, 0xb550, 0x5355, 0x4daf, 0xa5b0, 0x4573, 0x52bf, 0xa9a8, 0xe950, 0x6aa0, 0xaea6, 0xab50, 0x4b60, 0xaae4, 0xa570, 0x5260, 0xf263, 0xd950, 0x5b57, 0x56a0, 0x96d0, 0x4dd5, 0x4ad0, 0xa4d0, 0xd4d4, 0xd250, 0xd558, 0xb540, 0xb6a0, 0x95a6, 0x95bf, 0x49b0, 0xa974, 0xa4b0, 0xb27a, 0x6a50, 0x6d40, 0xaf46, 0xab60, 0x9570, 0x4af5, 0x4970, 0x64b0, 0x74a3, 0xea50, 0x6b58, 0x5ac0, 0xab60, 0x96d5, 0x92e0, 0xc960, 0xd954, 0xd4a0, 0xda50, 0x7552, 0x56a0, 0xabb7, 0x25d0, 0x92d0, 0xcab5, 0xa950, 0xb4a0, 0xbaa4, 0xad50, 0x55d9, 0x4ba0, 0xa5b0, 0x5176, 0x52bf, 0xa930, 0x7954, 0x6aa0, 0xad50, 0x5b52, 0x4b60, 0xa6e6, 0xa4e0, 0xd260, 0xea65, 0xd530, 0x5aa0, 0x76a3, 0x96d0, 0x4afb, 0x4ad0, 0xa4d0, 0xd0b6, 0xd25f, 0xd520, 0xdd45, 0xb5a0, 0x56d0, 0x55b2, 0x49b0, 0xa577, 0xa4b0, 0xaa50, 0xb255, 0x6d2f, 0xada0, 0x4b63, 0x937f, 0x49f8, 0x4970, 0x64b0, 0x68a6, 0xea5f, 0x6b20, 0xa6c4, 0xaaef, 0x92e0, 0xd2e3, 0xc960, 0xd557, 0xd4a0, 0xda50, 0x5d55, 0x56a0, 0xa6d0, 0x55d4, 0x52d0, 0xa9b8, 0xa950, 0xb4a0, 0xb6a6, 0xad50, 0x55a0, 0xaba4, 0xa5b0, 0x52b0, 0xb273, 0x6930, 0x7337, 0x6aa0, 0xad50, 0x4b55, 0x4b6f, 0xa570, 0x54e4, 0xd260, 0xe968, 0xd520, 0xdaa0, 0x6aa6, 0x56df, 0x4ae0, 0xa9d4, 0xa4d0, 0xd150, 0xf252, 0xd520);
  26.   private var tao_txtsolarMonth = new Array(31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
  27.   //定义私有函数干支等信息
  28.   private var Gan = new Array("甲""乙""丙""丁""戊""己""庚""辛""壬""癸");
  29.   private var Zhi = new Array("子""丑""寅""卯""辰""巳""午""未""申""酉""戌""亥");
  30.   private var Animals = new Array("鼠""牛""虎""兔""龙""蛇""马""羊""猴""鸡""狗""猪");
  31.   //农历节气
  32.   private var tao_txtsolarTerm = new Array("小寒""大寒""立春""雨水""惊蛰""春分""清明""谷雨""立夏""小满""芒种""夏至""小暑""大暑""立秋""处暑""白露""秋分""寒露""霜降""立冬""小雪""大雪""冬至");
  33.   private var tao_txtsTermInfo = new Array(0, 21208, 42467, 63836, 85337, 107014, 128867, 150921, 173149, 195551, 218072, 240693, 263343, 285989, 308563, 331033, 353350, 375494, 397447, 419210, 440795, 462224, 483532, 504758);
  34.   private var nStr1 = new Array('日''一''二''三''四''五''六''七''八''九''十');
  35.   private var nStr2 = new Array('初''十''廿''卅''□');
  36.   private var monthName = new Array("JAN""FEB""MAR""APR""MAY""JUN""JUL""AUG""SEP""OCT""NOV""DEC");
  37.   private var cyear:Number;
  38.   private var cmonth:Number;
  39.   private var cday:Number;
  40.   private var isLeap:Boolean;
  41.   private var nianzhu:String;
  42.   private var yuezhu:String;
  43.   private var rizhu:String;
  44.   private var jie:String;
  45.   public function Taoshaw_data(yearOrTimevalue:Number, month:Number, date:Number, hour:Number, minute:Number, second:Number, millisecond:Number) {
  46.     super(yearOrTimevalue, month, date, hour, minute, second, millisecond);
  47.     var leap:Number = 0;
  48.     var temp:Number = 0;
  49.     var y:Number, m:Number, d;
  50.     Number;
  51.     y = getFullYear();
  52.     m = getMonth();
  53.     d = getDate();
  54.     var offset = (Date.UTC(y, m, d)-Date.UTC(1900, 0, 31))/86400000;
  55.     for (var i = 1900; i<2100 && offset>0; i++) {
  56.       temp = lYearDays(i);
  57.       offset -= temp;
  58.     }
  59.     if (offset<0) {
  60.       offset += temp;
  61.       i--;
  62.     }
  63.     cyear = i;
  64.     leap = leapMonth(i);
  65.     isLeap = false;
  66.     for (var i = 1; i<13 && offset>0; i++) {
  67.       if (leap>0 && i == (leap+1) && isLeap == false) {
  68.         --i;
  69.         isLeap = true;
  70.         temp = leapDays(cyear);
  71.       } else {
  72.         temp = monthDays(cyear, i);
  73.       }
  74.       if (isLeap == true && i == (leap+1)) {
  75.         isLeap = false;
  76.       }
  77.       offset -= temp;
  78.     }
  79.     if (offset == 0 && leap>0 && i == leap+1) {
  80.       if (isLeap) {
  81.         isLeap = false;
  82.       } else {
  83.         isLeap = true;
  84.         --i;
  85.       }
  86.     }
  87.     if (offset<0) {
  88.       offset += temp;
  89.       --i;
  90.     }
  91.     cmonth = i;
  92.     cday = offset+1;
  93.     var cY, cM, cD;
  94.     if (m<2) {
  95.       cY = cyclical(y-1900+36-1);
  96.     } else {
  97.       cY = cyclical(y-1900+36);
  98.     }
  99.     cM = cyclical((y-1900)*12+m+12);
  100.     var tmp1 = sTerm(y, m*2);
  101.     var tmp2 = sTerm(y, m*2+1);
  102.     if (d == tmp1) {
  103.       jie = tao_txtsolarTerm[m*2];
  104.     } else {
  105.       if (d == tmp2) {
  106.         jie = tao_txtsolarTerm[m*2+1];
  107.       } else {
  108.         jie = "";
  109.       }
  110.     }
  111.     this.jie = jie;
  112.     //---------------------------------------------
  113.     var term2 = sTerm(y, 2);
  114.     var firstNode = sTerm(y, m*2);
  115.     if (m == 1 && d>=term2) {
  116.       cY = cyclical(y-1900+36);
  117.       trace("新年柱"+cY);
  118.     }
  119.     if ((d+1)>=firstNode) {
  120.       cM = cyclical((y-1900)*12+m+13);
  121.     }
  122.     var dayCyclical = Date.UTC(y, m, 1, 0, 0, 0, 0)/86400000+25567+10;
  123.     cD = cyclical(dayCyclical+d-1);
  124.     nianzhu = cY;
  125.     yuezhu = cM;
  126.     rizhu = cD;
  127.   }
  128.   public function getTaosJYear():Number {
  129.     return cyear;
  130.   }
  131.   public function getTaoJMonth():Number {
  132.     return cmonth;
  133.   }
  134.   public function getTaoJDay():Number {
  135.     return cday;
  136.   }
  137.   //getmonth() 得到的比当前月份小1.因为是以数组形式来存储月份的。下标是从0-11.
  138.   public function getnewMonth():Number {
  139.     return getMonth()+1;
  140.   }
  141.   public function getTaoJNianZhu():String {
  142.     return nianzhu;
  143.   }
  144.   public function getYueZhu():String {
  145.     return yuezhu;
  146.   }
  147.   public function getRiZhu():String {
  148.     return rizhu;
  149.   }
  150.   public function getJieQi():String {
  151.     return jie;
  152.   }
  153.   public function getShiceng():String {
  154.     return Zhi[Math.round((getHours()%23)/2)]+"时";
  155.   }
  156.   private function lYearDays(y) {
  157.     var sum:Number = 348;
  158.     for (var i = 0x8000; i>0x8; i >>= 1) {
  159.       sum += (tao_txtnum_info[y-1900] & i) ? 1 : 0;
  160.     }
  161.     return (sum+leapDays(y));
  162.   }
  163.   private function leapDays(y) {
  164.     if (leapMonth(y)) {
  165.       return ((tao_txtnum_info[y-1899] & 0xf) == 0xf ? 30 : 29);
  166.     } else {
  167.       return (0);
  168.     }
  169.   }
  170.   private function leapMonth(y) {
  171.     var lm = tao_txtnum_info[y-1900] & 0xf;
  172.     return (lm == 0xf ? 0 : lm);
  173.   }
  174.   private function monthDays(y, m) {
  175.     return ((tao_txtnum_info[y-1900] & (0x10000 >> m)) ? 30 : 29);
  176.   }
  177.   private function sTerm(y, n) {
  178.     var offDate = new Date((31556925974.7*(y-1900)+tao_txtsTermInfo[n]*60000)+Date.UTC(1900, 0, 6, 2, 5));
  179.     return (offDate.getUTCDate());
  180.   }
  181.   private function solarDays(y, m) {
  182.     if (m == 1) {
  183.       return (((y%4 == 0) && (y%100 != 0) || (y%400 == 0)) ? 29 : 28);
  184.     } else {
  185.       return (tao_txtsolarMonth[m]);
  186.     }
  187.   }
  188.   private function cyclical(num) {
  189.     return (Gan[num%10]+Zhi[num%12]);
  190.   }
  191. }
  192. 保存。
  193. 2、用法上面也写得有。在FLASH中调用的时候。请参考如下代码:
  194. /*
  195. getFullYear();获取新历年份
  196. getnewMonth();获取月份,如果像本例这样,独立用数组表示,就直接用getMonth()获取,因为数组会少一个值.是从0开始的.
  197. getDate()获取多少号.
  198. getSeconds();获取秒值
  199. getDay();获取星期几
  200. getHours();获取小时(整点)
  201. getMinutes();获取分数
  202. getTaosJYear();获取中国农历年.
  203. getTaoJMonth(); 获取中国农历月.
  204. getTaoJDay();获取中国农历日.
  205. getTaoJNianZhu();获取年柱
  206. getYueZhu();获取月柱
  207. getRiZhu();获取日柱
  208. getShiceng();获取时辰
  209. getJieQi();获取二十四节气
  210. */
  211. //定义新Taoshaw_data类,因为Taoshaw_data类继承于data类,所以在此直接使用此类即可.
  212. //需要实时更新时,就加onEnterFrame函数.
  213. onEnterFrame = function () {
  214.   var my_data:Taoshaw_data = new Taoshaw_data();
  215.   //定义两个数组,用于显示**月,以及星期*
  216.   var my_xingqi:Array = new Array();
  217.   my_xingqi = ["星期日""星期一""星期二""星期三""星期四""星期五""星期六"];
  218.   var my_yuefen:Array = new Array();
  219.   my_yuefen = ["1月""2月""3月""4月""5月""6月""7月""8月""9月""10月""11月""12月"];
  220.   //定义变量myhaoshu获取当前日的号数
  221.   var myhaoshu = my_data.getDate();
  222.   //当数值小于10的时候,就在前面添加一个0;
  223.   var miao = my_data.getSeconds();
  224.   var fen = my_data.getMinutes();
  225.   if (fen<10) {
  226.     fen = "0"+fen;
  227.   } else {
  228.   }
  229.   if (miao<10) {
  230.     miao = "0"+miao;
  231.   } else {
  232.   }
  233.   if (myhaoshu<10) {
  234.     myhaoshu = "0"+myhaoshu;
  235.   } else {
  236.   }
  237.   show_txt.text = "现在是"+my_data.getFullYear()+"年"+my_yuefen[my_data.getMonth()]+myhaoshu+"号"+my_xingqi[my_data.getDay()]+my_data.getHours()+"时"+fen+"分"+miao+"秒。"+"旧历"+my_data.getTaosJYear()+"."+my_data.getTaoJMonth()+"."+my_data.getTaoJDay()+"农历"+my_data.getTaoJNianZhu()+"年"+my_data.getYueZhu()+"月"+my_data.getRiZhu()+"日"+my_data.getShiceng()+my_data.getJieQi();
  238. };

源码下载:http://download.csdn.net/source/830951

六、C++代码

1、头文件

  1. //xDate.h 
  2. /************************************************************************************************************ 
  3.                Author  :xShandow 
  4.          Dest    :A Date Class For C++ 
  5.          Email   :[email protected] 
  6.          HomePage:http://www.hftd.com 
  7.          Dev Env :Visual C++6.0 
  8.          OS.     :Windows 2000 Professinal 
  9.          Date    :2003-NOV-15 
  10. ************************************************************************************************************/ 
  11. #ifndef XDATE_H 
  12. #define XDATE_H  
  13. #include  
  14. extern const WORD START_YEAR; 
  15. extern const WORD END_YEAR ; 
  16. class xDate 
  17. private
  18.    WORD    m_iYear, m_iMonth, m_iDay; 
  19.    void    l_InitData(); 
  20.    //计算从1901年1月1日过iSpanDays天后的阴历日期    
  21.    static void   l_CalcLunarDate(WORD &iYear, WORD &iMonth ,WORD &iDay,LONG iSpanDays); 
  22.    //计算公历iYear年iMonth月iDay日对应的节气 0-24,0表不是节气 
  23.    static WORD   l_GetLunarHolDay(WORD iYear, WORD iMonth, WORD iDay); 
  24. public:  
  25.    //=====================================================================================// 
  26.    xDate(WORD iYear, WORD iMonth, WORD iDay);  
  27.    xDate(); 
  28.    //=====================================================================================// 
  29.    WORD GetYear(){return m_iYear;}  
  30.    WORD GetMonth(){return m_iMonth;} 
  31.    WORD GetDay(){return m_iDay;}  
  32.     
  33.    //=====================================================================================// 
  34.    void GetDate(WORD &iYear, WORD &iMonth, WORD &iDay);  
  35.    BOOL SetDate(WORD iYear , WORD iMonth , WORD iDay); 
  36.    //=====================================================================================// 
  37.    //判断iYear是不是闰年  
  38.     static BOOL IsLeapYear(WORD iYear)  {return !(iYear%4)&&(iYear%100) || !(iYear%400);}  
  39.     
  40.    //计算iYear,iMonth,iDay对应是星期几 1年1月1日 --- 65535年12月31日  
  41.    static WORD WeekDay(WORD iYear, WORD iMonth, WORD iDay); 
  42.     
  43.    //返回iYear年iMonth月的天数 1年1月 --- 65535年12月  
  44.    static WORD MonthDays(WORD iYear, WORD iMonth);  
  45.     
  46.    //返回阴历iLunarYer年阴历iLunarMonth月的天数,如果iLunarMonth为闰月, 
  47.    //高字为第二个iLunarMonth月的天数,否则高字为0  
  48.    // 1901年1月---2050年12月  
  49.    static LONG LunarMonthDays(WORD iLunarYear, WORD iLunarMonth);  
  50.     
  51.    //返回阴历iLunarYear年的总天数 
  52.    // 1901年1月---2050年12月  
  53.    static WORD LunarYearDays(WORD iLunarYear);  
  54.     
  55.    //返回阴历iLunarYear年的闰月月份,如没有返回0  
  56.    // 1901年1月---2050年12月 
  57.    static WORD GetLeapMonth(WORD iLunarYear);  
  58.     
  59.    //把iYear年格式化成天干记年法表示的字符串  
  60.    static void FormatLunarYear(WORD  iYear, char *pBuffer);  
  61.    //把iMonth格式化成中文字符串  
  62.    static void FormatMonth(WORD iMonth, char *pBuffer, BOOL bLunar = TRUE);  
  63.     
  64.    //把iDay格式化成中文字符串  
  65.    static void FormatLunarDay(WORD  iDay, char *pBuffer); 
  66.     
  67.    //计算公历两个日期间相差的天数  1年1月1日 --- 65535年12月31日  
  68.    static LONG CalcDateDiff(WORD iEndYear, WORD iEndMonth, WORD iEndDay,WORD iStartYear = START_YEAR,WORD iStartMonth =1, WORD iStartDay =1);  
  69.     
  70.    //计算公历iYear年iMonth月iDay日对应的阴历日期,返回对应的阴历节气 0-24 
  71.    //1901年1月1日---2050年12月31日  
  72.    static WORD GetLunarDate(WORD iYear, WORD iMonth, WORD iDay,WORD &iLunarYear, WORD &iLunarMonth, WORD &iLunarDay); 
  73. };  
  74. #endif //XDATE_H 

2、实现文件

  1. //xDate.cpp 
  2. #include "xDate.h"  
  3. //#include  
  4. extern WORD gLunarMonthDay[];  
  5. extern BYTE gLunarMonth[];  
  6. extern BYTE gLunarHolDay[];  
  7. const  WORD START_YEAR =1901;  
  8. const  WORD END_YEAR   =2050;  
  9. //===========================================================================// 
  10. void xDate::l_InitData()  
  11. {  
  12.    SYSTEMTIME systime;  
  13.    ::GetSystemTime(&systime);  
  14.     
  15.    m_iYear  = systime.wYear;  
  16.    m_iMonth = systime.wMonth;  
  17.    m_iDay   = systime.wDay;  
  18. }  
  19. //===========================================================================// 
  20. xDate::xDate(WORD iYear, WORD iMonth, WORD iDay)  
  21. {  
  22.    if(!SetDate(iYear, iMonth, iDay))  
  23.       l_InitData();  
  24. }  
  25. //===========================================================================// 
  26. xDate::xDate()  
  27. {  
  28.    l_InitData();  
  29. }  
  30. //===========================================================================// 
  31. LONG xDate::CalcDateDiff(WORD iEndYear, WORD iEndMonth, WORD iEndDay,WORD  iStartYear, WORD iStartMonth, WORD iStartDay)  
  32. {  
  33.    WORD monthday[]={0, 31, 59 ,90, 120, 151, 181, 212, 243, 273, 304, 334};  
  34.    //计算两个年份1月1日之间相差的天数  
  35.    LONG iDiffDays =(iEndYear - iStartYear)*365;  
  36.    iDiffDays += (iEndYear-1)/4 - (iStartYear-1)/4;  
  37.    iDiffDays -= ((iEndYear-1)/100 - (iStartYear-1)/100);  
  38.    iDiffDays += (iEndYear-1)/400 - (iStartYear-1)/400;  
  39.    //加上iEndYear年1月1日到iEndMonth月iEndDay日之间的天数  
  40.    iDiffDays += monthday[iEndMonth-1] +  
  41.       (IsLeapYear(iEndYear)&&iEndMonth>2? 1: 0);  
  42.    iDiffDays += iEndDay;  
  43.    //减去iStartYear年1月1日到iStartMonth月iStartDay日之间的天数  
  44.    iDiffDays -= (monthday[iStartMonth-1] +(IsLeapYear(iStartYear)&&iStartMonth>2 ? 1: 0));  
  45.    iDiffDays -= iStartDay;  
  46.    return iDiffDays;  
  47. }  
  48. //===========================================================================// 
  49. void  xDate::l_CalcLunarDate(WORD &iYear, WORD &iMonth ,WORD &iDay, LONG iSpanDays)  
  50. {  
  51.    //阳历1901年2月19日为阴历1901年正月初一  
  52.    //阳历1901年1月1日到2月19日共有49天  
  53.    if(iSpanDays <49) 
  54.    { 
  55.       iYear = START_YEAR-1; 
  56.       if(iSpanDays <19) 
  57.       { 
  58.          iMonth = 11; 
  59.          iDay = 11+WORD(iSpanDays); 
  60.       } 
  61.       else 
  62.       { 
  63.          iMonth = 12; 
  64.          iDay = WORD(iSpanDays) -18; 
  65.       } 
  66.       return ; 
  67.    } 
  68.    //下面从阴历1901年正月初一算起 
  69.    iSpanDays -=49; 
  70.    iYear = START_YEAR; 
  71.    iMonth = 1; 
  72.    iDay = 1; 
  73.    //计算年 
  74.    LONG tmp = LunarYearDays(iYear); 
  75.    while(iSpanDays >= tmp)  
  76.    {  
  77.       iSpanDays -= tmp;  
  78.       tmp = LunarYearDays(++iYear);  
  79.    }  
  80.    //计算月  
  81.    tmp = LOWORD(LunarMonthDays(iYear, iMonth));  
  82.    while(iSpanDays >= tmp)  
  83.    {  
  84.       iSpanDays -= tmp;  
  85.       if(iMonth == GetLeapMonth(iYear))  
  86.       {  
  87.          tmp  = HIWORD(LunarMonthDays(iYear, iMonth));  
  88.          if(iSpanDays < tmp) 
  89.             break
  90.          iSpanDays -= tmp; 
  91.       } 
  92.       tmp = LOWORD(LunarMonthDays(iYear, ++iMonth)); 
  93.    } 
  94.    //计算日 
  95.    iDay += WORD(iSpanDays); 
  96. //===========================================================================// 
  97. WORD xDate::GetLunarDate(WORD iYear, WORD iMonth, WORD iDay,WORD &iLunarYear, WORD &iLunarMonth, WORD &iLunarDay) 
  98.    l_CalcLunarDate(iLunarYear, iLunarMonth, iLunarDay,CalcDateDiff(iYear, iMonth, iDay)); 
  99.    return l_GetLunarHolDay(iYear, iMonth, iDay); 
  100. //===========================================================================// 
  101. //根据节气数据存储格式,计算阳历iYear年iMonth月iDay日对应的节气, 
  102. WORD xDate::l_GetLunarHolDay(WORD iYear, WORD iMonth, WORD iDay) 
  103.    BYTE &flag = gLunarHolDay[(iYear - START_YEAR)*12+iMonth -1]; 
  104.    WORD day; 
  105.    if(iDay <15) 
  106.       day= 15 - ((flag>>4)&0x0f);  
  107.    else  
  108.       day = ((flag)&0x0f)+15;  
  109.    if(iDay == day)  
  110.       return (iMonth-1) *2 + (iDay>15? 1: 0) +1;  
  111.    else  
  112.       return 0;  
  113. }  
  114. //===========================================================================// 
  115. void xDate::GetDate(WORD &iYear, WORD &iMonth, WORD &iDay)  
  116. {  
  117.    iYear  = m_iYear;  
  118.    iMonth = m_iMonth;  
  119.    iDay   = m_iDay;  
  120. }  
  121. //===========================================================================// 
  122. BOOL xDate::SetDate(WORD iYear, WORD iMonth, WORD iDay)  
  123. {  
  124.    if(iYear < START_YEAR || iYear > END_YEAR || iMonth <1 || iMonth >12)  
  125.       return FALSE;  
  126.     
  127.    if(iDay <1 || iDay > MonthDays(iYear, iMonth))  
  128.       return FALSE;  
  129.     
  130.    m_iYear   = iYear;  
  131.    m_iMonth  = iMonth;  
  132.    m_iDay    = iDay;  
  133.     
  134.    return TRUE;  
  135. }  
  136. //===========================================================================// 
  137. WORD xDate::WeekDay(WORD iYear, WORD iMonth, WORD iDay)  
  138. {  
  139.    //数组元素monthday表示第i个月以前的总天数除以7的余数  
  140.    WORD monthday[]={0,3,3,6,1,4,6,2,5,0,3,5};  
  141.    WORD iDays = (iYear-1)%7 + (iYear-1)/4 - (iYear-1)/100 +(iYear-1)/400;  
  142.    iDays += (monthday[iMonth-1] +iDay) ;  
  143.    //如果iYear是闰年  
  144.    if(IsLeapYear(iYear) && iMonth>2)  
  145.       iDays++;  
  146.    //返回:0,1,2,3,4,5,6表日、一、二、三、四、五、六  
  147.    return iDays%7;  
  148. }  
  149. //===========================================================================// 
  150. WORD xDate::MonthDays(WORD iYear, WORD iMonth)  
  151. {  
  152.    switch(iMonth)  
  153.    {  
  154.    case 1: //一  (月) 
  155.    case 3: //三  (月) 
  156.    case 5: //五  (月) 
  157.    case 7: //七  (月) 
  158.    case 8: //八  (月) 
  159.    case 10://十  (月) 
  160.    case 12://十二(月) 
  161.       return 31;  
  162.    case 4: //四  (月) 
  163.    case 6: //六  (月) 
  164.    case 9: //九  (月) 
  165.    case 11://十一(月)  
  166.       return 30;  
  167.    case 2: //二  (月) 
  168.       //如果是闰年  
  169.       if(IsLeapYear(iYear))  
  170.          return 29;  
  171.       else  
  172.          return 28;  
  173.         
  174.    }  
  175.    return 0;  
  176. }  
  177. //===========================================================================// 
  178. WORD xDate::GetLeapMonth(WORD iLunarYear)  
  179. {  
  180.    BYTE &flag = gLunarMonth[(iLunarYear - START_YEAR)/2];  
  181.    return  (iLunarYear - START_YEAR)%2 ? flag&0x0f : flag>>4;  
  182. }  
  183. //===========================================================================// 
  184. LONG xDate::LunarMonthDays(WORD iLunarYear, WORD iLunarMonth)  
  185. {  
  186.    if(iLunarYear < START_YEAR) 
  187.       return 30L; 
  188.     
  189.    WORD height =0 ,low =29; 
  190.    int iBit = 16 - iLunarMonth; 
  191.     
  192.    if(iLunarMonth > GetLeapMonth(iLunarYear) && GetLeapMonth(iLunarYear))  
  193.       iBit --;  
  194.     
  195.    if(gLunarMonthDay[iLunarYear - START_YEAR] & (1<
  196.       low ++; 
  197.     
  198.    if(iLunarMonth == GetLeapMonth(iLunarYear)) 
  199.       if(gLunarMonthDay[iLunarYear - START_YEAR] & (1<< (iBit -1))) 
  200.          height =30; 
  201.       else 
  202.          height =29; 
  203.        
  204.       return MAKELONG(low, height); 
  205. //===========================================================================// 
  206. WORD xDate::LunarYearDays(WORD iLunarYear) 
  207. /* 
  208.    WORD days=348 ; //12*29 
  209.    int month = 12 ; 
  210.     
  211.    //如果iYear年有闰月,则为13个月 
  212.    if(gLanarMonth[iYear - START_YEAR]) 
  213.       month ++; 
  214.    //如果某月是三十天则days++ 
  215.    while(month >=0 && (gLanarMonthDay[iYear - START_YEAR] & (1 << (16 - month)))) 
  216.    { 
  217.       days ++; 
  218.       month --; 
  219.    } 
  220.    return days; 
  221. */ 
  222.    WORD days =0; 
  223.    for(WORD i=1; i<=12; i++) 
  224.    { 
  225.       LONG tmp = LunarMonthDays(iLunarYear ,i); 
  226.       days += HIWORD(tmp); 
  227.       days += LOWORD(tmp); 
  228.    } 
  229.    return days; 
  230. //===========================================================================// 
  231. void xDate::FormatLunarYear(WORD iYear, char *pBuffer) 
  232.    char szText1[]="甲乙丙丁戊己庚辛壬癸"
  233.    char szText2[]="子丑寅卯辰巳午未申酉戌亥"
  234.    char szText3[]="鼠牛虎免龙蛇马羊猴鸡狗猪"
  235.     
  236.    memcpy(pBuffer  ,szText1+((iYear-4)%10)*2,2); 
  237.    memcpy(pBuffer+2,szText2+((iYear-4)%12)*2,2); 
  238.    pBuffer[4]=' '
  239.    memcpy(pBuffer+5,szText3+((iYear-4)%12)*2,2); 
  240.    strcpy(pBuffer+7,"年"); 
  241. //===========================================================================// 
  242. void xDate::FormatMonth(WORD iMonth, char *pBuffer, BOOL bLunar) 
  243.    if(!bLunar && iMonth==1) 
  244.    { 
  245.       strcpy(pBuffer, " 一月"); 
  246.       return
  247.    } 
  248.    char szText[]="正二三四五六七八九十"
  249.    if(iMonth<=10) 
  250.    { 
  251.       memcpy(pBuffer  ," ", 2); 
  252.       memcpy(pBuffer+2, szText + (iMonth -1)*2, 2); 
  253.       strcpy(pBuffer+4, "月"); 
  254.       return
  255.    } 
  256.    if (iMonth == 11) 
  257.       strcpy(pBuffer, "十一"); 
  258.    else 
  259.       strcpy(pBuffer, "十二"); 
  260.    strcpy(pBuffer+4  , "月"); 
  261.     
  262.     
  263. //===========================================================================// 
  264. void xDate::FormatLunarDay(WORD iDay, char *pBuffer) 
  265.    char szText1[]="初十廿三"
  266.    char szText2[]="一二三四五六七八九十"
  267.    if(iDay != 20 && iDay !=30) 
  268.    { 
  269.       memcpy(pBuffer  , szText1 + (iDay-1)/10*2   ,2); 
  270.       memcpy(pBuffer+2, szText2 + ((iDay-1)%10)*2 ,2); 
  271.       pBuffer[4]='/0'
  272.    } 
  273.    else 
  274.    { 
  275.       memcpy(pBuffer  , szText1 + iDay/10*2, 2); 
  276.       strcpy(pBuffer+2, szText2 +18); 
  277.    } 
  278.   
  279. /******************************************************************************  
  280. 下面为阴历计算所需的数据,为节省存储空间,所以采用下面比较变态的存储方法.  
  281. *******************************************************************************/  
  282. //数组gLunarDay存入阴历1901年到2100年每年中的月天数信息,  
  283. //阴历每月只能是29或30天,一年用12(或13)个二进制位表示,对应位为1表30天,否则为29天  
  284. WORD gLunarMonthDay[]=  
  285. {  
  286.    //测试数据只有1901.1.1 --2050.12.31  
  287.    0X4ae0, 0Xa570, 0X5268, 0Xd260, 0Xd950, 0X6aa8, 0X56a0, 0X9ad0, 0X4ae8, 0X4ae0,   //1910  
  288.    0Xa4d8, 0Xa4d0, 0Xd250, 0Xd548, 0Xb550, 0X56a0, 0X96d0, 0X95b0, 0X49b8, 0X49b0,   //1920  
  289.    0Xa4b0, 0Xb258, 0X6a50, 0X6d40, 0Xada8, 0X2b60, 0X9570, 0X4978, 0X4970, 0X64b0,   //1930  
  290.    0Xd4a0, 0Xea50, 0X6d48, 0X5ad0, 0X2b60, 0X9370, 0X92e0, 0Xc968, 0Xc950, 0Xd4a0,   //1940  
  291.    0Xda50, 0Xb550, 0X56a0, 0Xaad8, 0X25d0, 0X92d0, 0Xc958, 0Xa950, 0Xb4a8, 0X6ca0,   //1950  
  292.    0Xb550, 0X55a8, 0X4da0, 0Xa5b0, 0X52b8, 0X52b0, 0Xa950, 0Xe950, 0X6aa0, 0Xad50,   //1960  
  293.    0Xab50, 0X4b60, 0Xa570, 0Xa570, 0X5260, 0Xe930, 0Xd950, 0X5aa8, 0X56a0, 0X96d0,   //1970  
  294.    0X4ae8, 0X4ad0, 0Xa4d0, 0Xd268, 0Xd250, 0Xd528, 0Xb540, 0Xb6a0, 0X96d0, 0X95b0,   //1980  
  295.    0X49b0, 0Xa4b8, 0Xa4b0, 0Xb258, 0X6a50, 0X6d40, 0Xada0, 0Xab60, 0X9370, 0X4978,   //1990  
  296.    0X4970, 0X64b0, 0X6a50, 0Xea50, 0X6b28, 0X5ac0, 0Xab60, 0X9368, 0X92e0, 0Xc960,   //2000  
  297.    0Xd4a8, 0Xd4a0, 0Xda50, 0X5aa8, 0X56a0, 0Xaad8, 0X25d0, 0X92d0, 0Xc958, 0Xa950,   //2010  
  298.    0Xb4a0, 0Xb550, 0Xb550, 0X55a8, 0X4ba0, 0Xa5b0, 0X52b8, 0X52b0, 0Xa930, 0X74a8,   //2020  
  299.    0X6aa0, 0Xad50, 0X4da8, 0X4b60, 0X9570, 0Xa4e0, 0Xd260, 0Xe930, 0Xd530, 0X5aa0,   //2030  
  300.    0X6b50, 0X96d0, 0X4ae8, 0X4ad0, 0Xa4d0, 0Xd258, 0Xd250, 0Xd520, 0Xdaa0, 0Xb5a0,   //2040  
  301.    0X56d0, 0X4ad8, 0X49b0, 0Xa4b8, 0Xa4b0, 0Xaa50, 0Xb528, 0X6d20, 0Xada0, 0X55b0,   //2050  
  302.        
  303. };  
  304. //数组gLanarMonth存放阴历1901年到2050年闰月的月份,如没有则为0,每字节存两年  
  305. BYTE  gLunarMonth[]=  
  306. {  
  307.    0X00, 0X50, 0X04, 0X00, 0X20,   //1910  
  308.    0X60, 0X05, 0X00, 0X20, 0X70,   //1920  
  309.    0X05, 0X00, 0X40, 0X02, 0X06,   //1930  
  310.    0X00, 0X50, 0X03, 0X07, 0X00,   //1940  
  311.    0X60, 0X04, 0X00, 0X20, 0X70,   //1950  
  312.    0X05, 0X00, 0X30, 0X80, 0X06,   //1960  
  313.    0X00, 0X40, 0X03, 0X07, 0X00,   //1970  
  314.    0X50, 0X04, 0X08, 0X00, 0X60,   //1980  
  315.    0X04, 0X0a, 0X00, 0X60, 0X05,   //1990  
  316.    0X00, 0X30, 0X80, 0X05, 0X00,   //2000  
  317.    0X40, 0X02, 0X07, 0X00, 0X50,   //2010  
  318.    0X04, 0X09, 0X00, 0X60, 0X04,   //2020  
  319.    0X00, 0X20, 0X60, 0X05, 0X00,   //2030  
  320.    0X30, 0Xb0, 0X06, 0X00, 0X50,   //2040  
  321.    0X02, 0X07, 0X00, 0X50, 0X03    //2050  
  322. };  
  323. //数组gLanarHoliDay存放每年的二十四节气对应的阳历日期  
  324. //每年的二十四节气对应的阳历日期几乎固定,平均分布于十二个月中  
  325. //   1月          2月         3月         4月         5月         6月  
  326. //小寒 大寒   立春  雨水   惊蛰 春分   清明 谷雨   立夏 小满   芒种 夏至  
  327. //   7月          8月         9月         10月       11月        12月  
  328. //小暑 大暑   立秋  处暑   白露 秋分   寒露 霜降   立冬 小雪   大雪 冬至  
  329. /*********************************************************************************  
  330. 节气无任何确定规律,所以只好存表,要节省空间,所以....  
  331. 下面这种存法实在是太变态了,你就将就着看吧  
  332. **********************************************************************************/  
  333. //数据格式说明:  
  334. //如1901年的节气为  
  335. //  1月     2月     3月   4月    5月   6月   7月    8月   9月    10月  11月     12月  
  336. // 6, 21, 4, 19,  6, 21, 5, 21, 6,22, 6,22, 8, 23, 8, 24, 8, 24, 8, 24 , 8, 23, 8, 22  
  337. // 9, 6,  11,4,   9, 6,  10,6,  9,7,  9,7,  7, 8,  7, 9,  7,  9, 7,  9, 7,  8, 7, 15  
  338. //上面第一行数据为每月节气对应日期,15减去每月第一个节气,每月第二个节气减去15得第二行  
  339. // 这样每月两个节气对应数据都小于16,每月用一个字节存放,高位存放第一个节气数据,低位存放  
  340. //第二个节气的数据,可得下表  
  341. BYTE gLunarHolDay[]=  
  342. {  
  343.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1901  
  344.       0X96, 0XA4, 0X96, 0X96, 0X97, 0X87, 0X79, 0X79, 0X79, 0X69, 0X78, 0X78,   //1902  
  345.       0X96, 0XA5, 0X87, 0X96, 0X87, 0X87, 0X79, 0X69, 0X69, 0X69, 0X78, 0X78,   //1903  
  346.       0X86, 0XA5, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X79, 0X78, 0X87,   //1904  
  347.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1905  
  348.       0X96, 0XA4, 0X96, 0X96, 0X97, 0X97, 0X79, 0X79, 0X79, 0X69, 0X78, 0X78,   //1906  
  349.       0X96, 0XA5, 0X87, 0X96, 0X87, 0X87, 0X79, 0X69, 0X69, 0X69, 0X78, 0X78,   //1907  
  350.       0X86, 0XA5, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //1908  
  351.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1909  
  352.       0X96, 0XA4, 0X96, 0X96, 0X97, 0X97, 0X79, 0X79, 0X79, 0X69, 0X78, 0X78,   //1910  
  353.       0X96, 0XA5, 0X87, 0X96, 0X87, 0X87, 0X79, 0X69, 0X69, 0X69, 0X78, 0X78,   //1911  
  354.       0X86, 0XA5, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //1912  
  355.       0X95, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1913  
  356.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X79, 0X79, 0X79, 0X69, 0X78, 0X78,   //1914  
  357.       0X96, 0XA5, 0X97, 0X96, 0X97, 0X87, 0X79, 0X79, 0X69, 0X69, 0X78, 0X78,   //1915  
  358.       0X96, 0XA5, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X79, 0X77, 0X87,   //1916  
  359.       0X95, 0XB4, 0X96, 0XA6, 0X96, 0X97, 0X78, 0X79, 0X78, 0X69, 0X78, 0X87,   //1917  
  360.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X79, 0X79, 0X79, 0X69, 0X78, 0X77,   //1918  
  361.       0X96, 0XA5, 0X97, 0X96, 0X97, 0X87, 0X79, 0X79, 0X69, 0X69, 0X78, 0X78,   //1919  
  362.       0X96, 0XA5, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X79, 0X77, 0X87,   //1920  
  363.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X78, 0X79, 0X78, 0X69, 0X78, 0X87,   //1921  
  364.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X79, 0X79, 0X79, 0X69, 0X78, 0X77,   //1922  
  365.       0X96, 0XA4, 0X96, 0X96, 0X97, 0X87, 0X79, 0X79, 0X69, 0X69, 0X78, 0X78,   //1923  
  366.       0X96, 0XA5, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X79, 0X77, 0X87,   //1924  
  367.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X78, 0X79, 0X78, 0X69, 0X78, 0X87,   //1925  
  368.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1926  
  369.       0X96, 0XA4, 0X96, 0X96, 0X97, 0X87, 0X79, 0X79, 0X79, 0X69, 0X78, 0X78,   //1927  
  370.       0X96, 0XA5, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //1928  
  371.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X79, 0X77, 0X87,   //1929  
  372.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1930  
  373.       0X96, 0XA4, 0X96, 0X96, 0X97, 0X87, 0X79, 0X79, 0X79, 0X69, 0X78, 0X78,   //1931  
  374.       0X96, 0XA5, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //1932  
  375.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //1933  
  376.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1934  
  377.       0X96, 0XA4, 0X96, 0X96, 0X97, 0X97, 0X79, 0X79, 0X79, 0X69, 0X78, 0X78,   //1935  
  378.       0X96, 0XA5, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //1936  
  379.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //1937  
  380.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1938  
  381.       0X96, 0XA4, 0X96, 0X96, 0X97, 0X97, 0X79, 0X79, 0X79, 0X69, 0X78, 0X78,   //1939  
  382.       0X96, 0XA5, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //1940  
  383.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //1941  
  384.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1942  
  385.       0X96, 0XA4, 0X96, 0X96, 0X97, 0X97, 0X79, 0X79, 0X79, 0X69, 0X78, 0X78,   //1943  
  386.       0X96, 0XA5, 0X96, 0XA5, 0XA6, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //1944  
  387.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X79, 0X77, 0X87,   //1945  
  388.       0X95, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X78, 0X69, 0X78, 0X77,   //1946  
  389.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X79, 0X79, 0X79, 0X69, 0X78, 0X78,   //1947  
  390.       0X96, 0XA5, 0XA6, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X78, 0X78, 0X87, 0X87,   //1948  
  391.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X79, 0X78, 0X79, 0X77, 0X87,   //1949  
  392.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X78, 0X79, 0X78, 0X69, 0X78, 0X77,   //1950  
  393.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X79, 0X79, 0X79, 0X69, 0X78, 0X78,   //1951  
  394.       0X96, 0XA5, 0XA6, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X78, 0X78, 0X87, 0X87,   //1952  
  395.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X79, 0X77, 0X87,   //1953  
  396.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X78, 0X79, 0X78, 0X68, 0X78, 0X87,   //1954  
  397.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1955  
  398.       0X96, 0XA5, 0XA5, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X78, 0X78, 0X87, 0X87,   //1956  
  399.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X79, 0X77, 0X87,   //1957  
  400.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //1958  
  401.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1959  
  402.       0X96, 0XA4, 0XA5, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //1960  
  403.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //1961  
  404.       0X96, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //1962  
  405.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1963  
  406.       0X96, 0XA4, 0XA5, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //1964  
  407.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //1965  
  408.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //1966  
  409.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1967  
  410.       0X96, 0XA4, 0XA5, 0XA5, 0XA6, 0XA6, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //1968  
  411.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //1969  
  412.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //1970  
  413.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X79, 0X69, 0X78, 0X77,   //1971  
  414.       0X96, 0XA4, 0XA5, 0XA5, 0XA6, 0XA6, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //1972  
  415.       0XA5, 0XB5, 0X96, 0XA5, 0XA6, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //1973  
  416.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //1974  
  417.       0X96, 0XB4, 0X96, 0XA6, 0X97, 0X97, 0X78, 0X79, 0X78, 0X69, 0X78, 0X77,   //1975  
  418.       0X96, 0XA4, 0XA5, 0XB5, 0XA6, 0XA6, 0X88, 0X89, 0X88, 0X78, 0X87, 0X87,   //1976  
  419.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X88, 0X78, 0X78, 0X87, 0X87,   //1977  
  420.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X79, 0X78, 0X87,   //1978  
  421.       0X96, 0XB4, 0X96, 0XA6, 0X96, 0X97, 0X78, 0X79, 0X78, 0X69, 0X78, 0X77,   //1979  
  422.       0X96, 0XA4, 0XA5, 0XB5, 0XA6, 0XA6, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //1980  
  423.       0XA5, 0XB4, 0X96, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X78, 0X78, 0X77, 0X87,   //1981  
  424.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X79, 0X77, 0X87,   //1982  
  425.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X78, 0X79, 0X78, 0X69, 0X78, 0X77,   //1983  
  426.       0X96, 0XB4, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X88, 0X78, 0X87, 0X87,   //1984  
  427.       0XA5, 0XB4, 0XA6, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X78, 0X78, 0X87, 0X87,   //1985  
  428.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X79, 0X77, 0X87,   //1986  
  429.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X79, 0X78, 0X69, 0X78, 0X87,   //1987  
  430.       0X96, 0XB4, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X88, 0X78, 0X87, 0X86,   //1988  
  431.       0XA5, 0XB4, 0XA5, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //1989  
  432.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X79, 0X77, 0X87,   //1990  
  433.       0X95, 0XB4, 0X96, 0XA5, 0X86, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //1991  
  434.       0X96, 0XB4, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X88, 0X78, 0X87, 0X86,   //1992  
  435.       0XA5, 0XB3, 0XA5, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //1993  
  436.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //1994  
  437.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X76, 0X78, 0X69, 0X78, 0X87,   //1995  
  438.       0X96, 0XB4, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X88, 0X78, 0X87, 0X86,   //1996  
  439.       0XA5, 0XB3, 0XA5, 0XA5, 0XA6, 0XA6, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //1997  
  440.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //1998  
  441.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //1999  
  442.       0X96, 0XB4, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X88, 0X78, 0X87, 0X86,   //2000  
  443.       0XA5, 0XB3, 0XA5, 0XA5, 0XA6, 0XA6, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //2001  
  444.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //2002  
  445.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //2003  
  446.       0X96, 0XB4, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X88, 0X78, 0X87, 0X86,   //2004  
  447.       0XA5, 0XB3, 0XA5, 0XA5, 0XA6, 0XA6, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //2005  
  448.       0XA5, 0XB4, 0X96, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X78, 0X78, 0X87, 0X87,   //2006  
  449.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X69, 0X78, 0X87,   //2007  
  450.       0X96, 0XB4, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X87, 0X78, 0X87, 0X86,   //2008  
  451.       0XA5, 0XB3, 0XA5, 0XB5, 0XA6, 0XA6, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //2009  
  452.       0XA5, 0XB4, 0X96, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X78, 0X78, 0X87, 0X87,   //2010  
  453.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X79, 0X78, 0X87,   //2011  
  454.       0X96, 0XB4, 0XA5, 0XB5, 0XA5, 0XA6, 0X87, 0X88, 0X87, 0X78, 0X87, 0X86,   //2012  
  455.       0XA5, 0XB3, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X88, 0X78, 0X87, 0X87,   //2013  
  456.       0XA5, 0XB4, 0X96, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X78, 0X78, 0X87, 0X87,   //2014  
  457.       0X95, 0XB4, 0X96, 0XA5, 0X96, 0X97, 0X88, 0X78, 0X78, 0X79, 0X77, 0X87,   //2015  
  458.       0X95, 0XB4, 0XA5, 0XB4, 0XA5, 0XA6, 0X87, 0X88, 0X87, 0X78, 0X87, 0X86,   //2016  
  459.       0XA5, 0XC3, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X88, 0X78, 0X87, 0X87,   //2017  
  460.       0XA5, 0XB4, 0XA6, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X78, 0X78, 0X87, 0X87,   //2018  
  461.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X79, 0X77, 0X87,   //2019  
  462.       0X95, 0XB4, 0XA5, 0XB4, 0XA5, 0XA6, 0X97, 0X87, 0X87, 0X78, 0X87, 0X86,   //2020  
  463.       0XA5, 0XC3, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X88, 0X78, 0X87, 0X86,   //2021  
  464.       0XA5, 0XB4, 0XA5, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //2022  
  465.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X79, 0X77, 0X87,   //2023  
  466.       0X95, 0XB4, 0XA5, 0XB4, 0XA5, 0XA6, 0X97, 0X87, 0X87, 0X78, 0X87, 0X96,   //2024  
  467.       0XA5, 0XC3, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X88, 0X78, 0X87, 0X86,   //2025  
  468.       0XA5, 0XB3, 0XA5, 0XA5, 0XA6, 0XA6, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //2026  
  469.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //2027  
  470.       0X95, 0XB4, 0XA5, 0XB4, 0XA5, 0XA6, 0X97, 0X87, 0X87, 0X78, 0X87, 0X96,   //2028  
  471.       0XA5, 0XC3, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X88, 0X78, 0X87, 0X86,   //2029  
  472.       0XA5, 0XB3, 0XA5, 0XA5, 0XA6, 0XA6, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //2030  
  473.       0XA5, 0XB4, 0X96, 0XA5, 0X96, 0X96, 0X88, 0X78, 0X78, 0X78, 0X87, 0X87,   //2031  
  474.       0X95, 0XB4, 0XA5, 0XB4, 0XA5, 0XA6, 0X97, 0X87, 0X87, 0X78, 0X87, 0X96,   //2032  
  475.       0XA5, 0XC3, 0XA5, 0XB5, 0XA6, 0XA6, 0X88, 0X88, 0X88, 0X78, 0X87, 0X86,   //2033  
  476.       0XA5, 0XB3, 0XA5, 0XA5, 0XA6, 0XA6, 0X88, 0X78, 0X88, 0X78, 0X87, 0X87,   //2034  
  477.       0XA5, 0XB4, 0X96, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X78, 0X78, 0X87, 0X87,   //2035  
  478.       0X95, 0XB4, 0XA5, 0XB4, 0XA5, 0XA6, 0X97, 0X87, 0X87, 0X78, 0X87, 0X96,   //2036  
  479.       0XA5, 0XC3, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X88, 0X78, 0X87, 0X86,   //2037  
  480.       0XA5, 0XB3, 0XA5, 0XA5, 0XA6, 0XA6, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //2038  
  481.       0XA5, 0XB4, 0X96, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X78, 0X78, 0X87, 0X87,   //2039  
  482.       0X95, 0XB4, 0XA5, 0XB4, 0XA5, 0XA6, 0X97, 0X87, 0X87, 0X78, 0X87, 0X96,   //2040  
  483.       0XA5, 0XC3, 0XA5, 0XB5, 0XA5, 0XA6, 0X87, 0X88, 0X87, 0X78, 0X87, 0X86,   //2041  
  484.       0XA5, 0XB3, 0XA5, 0XB5, 0XA6, 0XA6, 0X88, 0X88, 0X88, 0X78, 0X87, 0X87,   //2042  
  485.       0XA5, 0XB4, 0X96, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X78, 0X78, 0X87, 0X87,   //2043  
  486.       0X95, 0XB4, 0XA5, 0XB4, 0XA5, 0XA6, 0X97, 0X87, 0X87, 0X88, 0X87, 0X96,   //2044  
  487.       0XA5, 0XC3, 0XA5, 0XB4, 0XA5, 0XA6, 0X87, 0X88, 0X87, 0X78, 0X87, 0X86,   //2045  
  488.       0XA5, 0XB3, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X88, 0X78, 0X87, 0X87,   //2046  
  489.       0XA5, 0XB4, 0X96, 0XA5, 0XA6, 0X96, 0X88, 0X88, 0X78, 0X78, 0X87, 0X87,   //2047  
  490.       0X95, 0XB4, 0XA5, 0XB4, 0XA5, 0XA5, 0X97, 0X87, 0X87, 0X88, 0X86, 0X96,   //2048  
  491.       0XA4, 0XC3, 0XA5, 0XA5, 0XA5, 0XA6, 0X97, 0X87, 0X87, 0X78, 0X87, 0X86,   //2049  
  492.       0XA5, 0XC3, 0XA5, 0XB5, 0XA6, 0XA6, 0X87, 0X88, 0X78, 0X78, 0X87, 0X87    //2050  
  493.        
  494. };

(感谢baickl)

七、C语言(1):

前段时间做软件写了个公历转农历的函数,目前公开给大家参考,有兴趣的朋友可以在此基础上进一步完善其功能。

  1.  /*------------农历转换函数-----------*/
  2. char *GetDayOf(PSYSTEMTIME pSt)
  3.  /*天干名称*/
  4.  const char *cTianGan[] = {"甲","乙","丙","丁","戊","己","庚","辛","壬","癸"};
  5.  /*地支名称*/
  6.  const char *cDiZhi[] = {"子","丑","寅","卯","辰","巳","午",
  7.        "未","申","酉","戌","亥"};
  8.  /*属相名称*/
  9.  const char *cShuXiang[] = {"鼠","牛","虎","兔","龙","蛇",
  10.        "马","羊","猴","鸡","狗","猪"};
  11.  /*农历日期名*/
  12.  const char *cDayName[] = {"*","初一","初二","初三","初四","初五",
  13.        "初六","初七","初八","初九","初十",
  14.        "十一","十二","十三","十四","十五",
  15.        "十六","十七","十八","十九","二十",
  16.        "廿一","廿二","廿三","廿四","廿五",       
  17.        "廿六","廿七","廿八","廿九","三十"};
  18.  /*农历月份名*/
  19.  const char *cMonName[] = {"*","正","二","三","四","五","六",
  20.        "七","八","九","十","十一","腊"};
  21.  /*公历每月前面的天数*/
  22.  const int wMonthAdd[12] = {0,31,59,90,120,151,181,212,243,273,304,334};
  23.  /*农历数据*/
  24.  const int wNongliData[100] = {2635,333387,1701,1748,267701,694,2391,133423,1175,396438
  25.        ,3402,3749,331177,1453,694,201326,2350,465197,3221,3402
  26.        ,400202,2901,1386,267611,605,2349,137515,2709,464533,1738
  27.        ,2901,330421,1242,2651,199255,1323,529706,3733,1706,398762
  28.        ,2741,1206,267438,2647,1318,204070,3477,461653,1386,2413
  29.        ,330077,1197,2637,268877,3365,531109,2900,2922,398042,2395
  30.        ,1179,267415,2635,661067,1701,1748,398772,2742,2391,330031
  31.        ,1175,1611,200010,3749,527717,1452,2742,332397,2350,3222
  32.        ,268949,3402,3493,133973,1386,464219,605,2349,334123,2709
  33.        ,2890,267946,2773,592565,1210,2651,395863,1323,2707,265877};
  34.  static int wCurYear,wCurMonth,wCurDay;
  35.  static int nTheDate,nIsEnd,m,k,n,i,nBit;
  36.  TCHAR szNongli[30], szNongliDay[10],szShuXiang[10];
  37.  /*---取当前公历年、月、日---*/
  38.  wCurYear = pSt->wYear;
  39.  wCurMonth = pSt->wMonth;
  40.  wCurDay = pSt->wDay;
  41.  /*---计算到初始时间1921年2月8日的天数:1921-2-8(正月初一)---*/
  42.  nTheDate = (wCurYear - 1921) * 365 + (wCurYear - 1921) / 4 + wCurDay + wMonthAdd[wCurMonth - 1] - 38;
  43.  if((!(wCurYear % 4)) && (wCurMonth > 2))
  44.   nTheDate = nTheDate + 1;
  45.  /*--计算农历天干、地支、月、日---*/
  46.  nIsEnd = 0;
  47.  m = 0;
  48.  while(nIsEnd != 1)
  49.  {
  50.   if(wNongliData[m] < 4095)
  51.    k = 11;
  52.   else
  53.    k = 12;
  54.   n = k;
  55.   while(n>=0)
  56.   {
  57.    //获取wNongliData(m)的第n个二进制位的值
  58.    nBit = wNongliData[m];
  59.    for(i=1;i
  60.     nBit = nBit/2;
  61.    nBit = nBit % 2;
  62.    if (nTheDate <= (29 + nBit))
  63.    {
  64.     nIsEnd = 1;
  65.     break;
  66.    }
  67.    nTheDate = nTheDate - 29 - nBit;
  68.    n = n - 1;
  69.   }
  70.   if(nIsEnd)
  71.    break;
  72.   m = m + 1;
  73.  }
  74.  wCurYear = 1921 + m;
  75.  wCurMonth = k - n + 1;
  76.  wCurDay = nTheDate;
  77.  if (k == 12)
  78.  {
  79.   if (wCurMonth == wNongliData[m] / 65536 + 1)
  80.    wCurMonth = 1 - wCurMonth;
  81.   else if (wCurMonth > wNongliData[m] / 65536 + 1)
  82.    wCurMonth = wCurMonth - 1;
  83.  }
  84.  /*--生成农历天干、地支、属相 ==> wNongli--*/
  85.  wsprintf(szShuXiang,"%s",cShuXiang[((wCurYear - 4) % 60) % 12]);
  86.  wsprintf(szNongli,"%s(%s%s)年",szShuXiang,cTianGan[((wCurYear - 4) % 60) % 10],cDiZhi[((wCurYear - 4) % 60) % 12]);
  87.  /*--生成农历月、日 ==> wNongliDay--*/
  88.  if (wCurMonth < 1)
  89.   wsprintf(szNongliDay,"闰%s",cMonName[-1 * wCurMonth]);
  90.  else
  91.   strcpy(szNongliDay,cMonName[wCurMonth]);
  92.  strcat(szNongliDay,"月");
  93.  strcat(szNongliDay,cDayName[wCurDay]);
  94.  return strcat(szNongli,szNongliDay);
  95. }

(感谢CSDN作者3661512)

八、C语言(2):

  1. /* 
  2. prototype: int calconv( struct convdate * ); 
  3. struct convdate 
  4. int source; ==0 则输入日期为西历, !=0 则输入为农历 
  5. int solaryear; 输出或输入之西历年份 
  6. int solarmonth; 西历月 
  7. int solardate; 西历日 
  8. int lunaryear; 输出或输入之农历年份 
  9. int lunarmonth; 农历月 
  10. int lunardate; 农历日 
  11. int weekday; 该日为星期几 ( 0==星期日, 1==星期一, ... ) 
  12. int kan; 该日天干 ( 0==甲, 1==乙, ..., 9==癸 ) 
  13. int chih; 该日地支 ( 0==子, 1==丑, ..., 11==亥 ) 
  14. }; 
  15. 呼叫时须设定 souce 的值, 若为 0 则为西历转农历, 否则为农历转西历. 然後视 
  16. 输入为西历或农历来设定西历或农历的年月日. 转换後的年月日会填入结构中( 农 
  17. 历或西历 ), 以及该日为星期几, 天干地支. 
  18. 若函式的返回值为 0 表示没有错误, 1 为输入之年份错误, 2 为输入之月份错误, 
  19. 3 为输入之日期错误. 
  20. 输入之西历年须在 1937 - 2031 间 
  21. 输入之农历年须在 1936 - 2030 间 
  22. 若须扩充, 则增加 lunarcal[] 
  23. */ 
  24. #define firstyear 1936 /* the first year in lunarcal[] */ 
  25. struct convdate 
  26. int source; 
  27. int solaryear; 
  28. int solarmonth; 
  29. int solardate; 
  30. int lunaryear; 
  31. int lunarmonth; 
  32. int lunardate; 
  33. int weekday; 
  34. int kan; 
  35. int chih; 
  36. }; 
  37. struct taglunarcal 
  38. int basedays; /* 到西历 1 月 1 日到农历正月初一的累积日数 */ 
  39. int intercalation; /* 闰月月份. 0==此年没有闰月 */ 
  40. int baseweekday; /* 此年西历 1 月 1 日为星期几再减 1 */ 
  41. int basekanchih; /* 此年西历 1 月 1 日之干支序号减 1 */ 
  42. int monthdays[13]; /* 此农历年每月之大小, 0==小月(29日), 1==大月(30日)*/ 
  43. }; 
  44. struct taglunarcal lunarcal[] = { 
  45. { 23, 3, 2, 17, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1, 1, 0 }, /* 1936 */ 
  46. { 41, 0, 4, 23, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1 }, 
  47. { 30, 7, 5, 28, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1 }, 
  48. { 49, 0, 6, 33, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1 }, 
  49. { 38, 0, 0, 38, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1 }, /* 1940 */ 
  50. { 26, 6, 2, 44, 1, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0 }, 
  51. { 45, 0, 3, 49, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0 }, 
  52. { 35, 0, 4, 54, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1 }, 
  53. { 24, 4, 5, 59, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1 }, /* 1944 */ 
  54. { 43, 0, 0, 5, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1, 1 }, 
  55. { 32, 0, 1, 10, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1 }, 
  56. { 21, 2, 2, 15, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1 }, 
  57. { 40, 0, 3, 20, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1 }, /* 1948 */ 
  58. { 28, 7, 5, 26, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1 }, 
  59. { 47, 0, 6, 31, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1 }, 
  60. { 36, 0, 0, 36, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0 }, 
  61. { 26, 5, 1, 41, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1 }, /* 1952 */ 
  62. { 44, 0, 3, 47, 0, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 0, 1 }, 
  63. { 33, 0, 4, 52, 1, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0 }, 
  64. { 23, 3, 5, 57, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1 }, 
  65. { 42, 0, 6, 2, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1 }, /* 1956 */ 
  66. { 30, 8, 1, 8, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0 }, 
  67. { 48, 0, 2, 13, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0 }, 
  68. { 38, 0, 3, 18, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1 }, 
  69. { 27, 6, 4, 23, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0 }, /* 1960 */ 
  70. { 45, 0, 6, 29, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0 }, 
  71. { 35, 0, 0, 34, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1 }, 
  72. { 24, 4, 1, 39, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0 }, 
  73. { 43, 0, 2, 44, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0 }, /* 1964 */ 
  74. { 32, 0, 4, 50, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1 }, 
  75. { 20, 3, 5, 55, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0 }, 
  76. { 39, 0, 6, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1, 0 }, 
  77. { 29, 7, 0, 5, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1 }, /* 1968 */ 
  78. { 47, 0, 2, 11, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1 }, 
  79. { 36, 0, 3, 16, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1, 0 }, 
  80. { 26, 5, 4, 21, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0, 1 }, 
  81. { 45, 0, 5, 26, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1 }, /* 1972 */ 
  82. { 33, 0, 0, 32, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1 }, 
  83. { 22, 4, 1, 37, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1 }, 
  84. { 41, 0, 2, 42, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1 }, 
  85. { 30, 8, 3, 47, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1 }, /* 1976 */ 
  86. { 48, 0, 5, 53, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1 }, 
  87. { 37, 0, 6, 58, 1, 0, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1 }, 
  88. { 27, 6, 0, 3, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1, 0 }, 
  89. { 46, 0, 1, 8, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1, 0 }, /* 1980 */ 
  90. { 35, 0, 3, 14, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1, 1 }, 
  91. { 24, 4, 4, 19, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1 }, 
  92. { 43, 0, 5, 24, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1 }, 
  93. { 32, 10, 6, 29, 1, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1 }, /* 1984 */ 
  94. { 50, 0, 1, 35, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0 }, 
  95. { 39, 0, 2, 40, 0, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1 }, 
  96. { 28, 6, 3, 45, 1, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1, 0, 0 }, 
  97. { 47, 0, 4, 50, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1 }, /* 1988 */ 
  98. { 36, 0, 6, 56, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1, 1, 0 }, 
  99. { 26, 5, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1 }, 
  100. { 45, 0, 1, 6, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0 }, 
  101. { 34, 0, 2, 11, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0 }, /* 1992 */ 
  102. { 22, 3, 4, 17, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0 }, 
  103. { 40, 0, 5, 22, 1, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0 }, 
  104. { 30, 8, 6, 27, 0, 1, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1 }, 
  105. { 49, 0, 0, 32, 0, 1, 0, 1, 1, 0, 1, 0, 1, 1, 0, 0, 1 }, /* 1996 */ 
  106. { 37, 0, 2, 38, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1 }, 
  107. { 27, 5, 3, 43, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1 }, 
  108. { 46, 0, 4, 48, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1 }, 
  109. { 35, 0, 5, 53, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1 }, /* 2000 */ 
  110. { 23, 4, 0, 59, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1 }, 
  111. { 42, 0, 1, 4, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1 }, 
  112. { 31, 0, 2, 9, 1, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0 }, 
  113. { 21, 2, 3, 14, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1 }, /* 2004 */ 
  114. { 39, 0, 5, 20, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1 }, 
  115. { 28, 7, 6, 25, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1 }, 
  116. { 48, 0, 0, 30, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1, 1 }, 
  117. { 37, 0, 1, 35, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1 }, /* 2008 */ 
  118. { 25, 5, 3, 41, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1 }, 
  119. { 44, 0, 4, 46, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1 }, 
  120. { 33, 0, 5, 51, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1 }, 
  121. { 22, 4, 6, 56, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0 }, /* 2012 */ 
  122. { 40, 0, 1, 2, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0 }, 
  123. { 30, 9, 2, 7, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1 }, 
  124. { 49, 0, 3, 12, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1, 0, 1 }, 
  125. { 38, 0, 4, 17, 1, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0 }, /* 2016 */ 
  126. { 27, 6, 6, 23, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1 }, 
  127. { 46, 0, 0, 28, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0 }, 
  128. { 35, 0, 1, 33, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0 }, 
  129. { 24, 4, 2, 38, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1 }, /* 2020 */ 
  130. { 42, 0, 4, 44, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1 }, 
  131. { 31, 0, 5, 49, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0 }, 
  132. { 21, 2, 6, 54, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1 }, 
  133. { 40, 0, 0, 59, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1 }, /* 2024 */ 
  134. { 28, 6, 2, 5, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0 }, 
  135. { 47, 0, 3, 10, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 0, 1 }, 
  136. { 36, 0, 4, 15, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1 }, 
  137. { 25, 5, 5, 20, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0 }, /* 2028 */ 
  138. { 43, 0, 0, 26, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1 }, 
  139. { 32, 0, 1, 31, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0 }, 
  140. { 22, 3, 2, 36, 0, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0 } }; 
  141. #define lastyear (firstyear+sizeof(lunarcal)/sizeof(struct taglunarcal)-1) 
  142. /* 西历年每月之日数 */ 
  143. int solarcal[12] = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 }; 
  144. /* 西历年每月之累积日数, 平年与闰年 */ 
  145. int solardays[2][14] = { 
  146. { 0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334, 365, 396 }, 
  147. { 0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335, 366, 397 } }; 
  148. /* 求此西历年是否为闰年, 返回 0 为平年, 1 为闰年 */ 
  149. int getleap( int year ) 
  150. if ( year % 400 == 0 ) 
  151. return 1; 
  152. else if ( year % 100 == 0 ) 
  153. return 0; 
  154. else if ( year % 4 == 0 ) 
  155. return 1; 
  156. else 
  157. return 0; 
  158. /* 西历农历转换 */ 
  159. int calconv( struct convdate *cd ) 
  160. int leap, d, sm, y, im, l1, l2, acc, i, lm, kc; 
  161. if ( cd->source == 0 ) /* solar */ 
  162. if ( cd->solaryear <= firstyear || cd->solaryear > lastyear ) 
  163. return 1; 
  164. sm = cd->solarmonth - 1; 
  165. if ( sm < 0 || sm > 11 ) 
  166. return 2; 
  167. leap = getleap( cd->solaryear ); 
  168. if ( sm == 1 ) 
  169. d = leap + 28; 
  170. else 
  171. d = solarcal[sm]; 
  172. if ( cd->solardate < 1 || cd->solardate > d ) 
  173. return 3; 
  174. y = cd->solaryear - firstyear; 
  175. acc = solardays[leap][sm] + cd->solardate; 
  176. cd->weekday = ( acc + lunarcal[y].baseweekday ) % 7; 
  177. kc = acc + lunarcal[y].basekanchih; 
  178. cd->kan = kc % 10; 
  179. cd->chih = kc % 12; 
  180. if ( acc <= lunarcal[y].basedays ) 
  181. y--; 
  182. cd->lunaryear = cd->solaryear - 1; 
  183. leap = getleap( cd->lunaryear ); 
  184. sm += 12; 
  185. acc = solardays[leap][sm] + cd->solardate; 
  186. else 
  187. cd->lunaryear = cd->solaryear; 
  188. l1 = lunarcal[y].basedays; 
  189. for ( i=0; i<13; i++ ) 
  190. l2 = l1 + lunarcal[y].monthdays[i] + 29; 
  191. if ( acc <= l2 ) 
  192. break
  193. l1 = l2; 
  194. cd->lunarmonth = i + 1; 
  195. cd->lunardate = acc - l1; 
  196. im = lunarcal[y].intercalation; 
  197. if ( im != 0 && cd->lunarmonth > im ) 
  198. cd->lunarmonth--; 
  199. if ( cd->lunarmonth == im ) 
  200. cd->lunarmonth = -im; 
  201. if ( cd->lunarmonth > 12 ) 
  202. cd->lunarmonth -= 12; 
  203. else /* lunar */ 
  204. if ( cd->lunaryear < firstyear || cd->lunaryear >= lastyear ) 
  205. return 1; 
  206. y = cd->lunaryear - firstyear; 
  207. im = lunarcal[y].intercalation; 
  208. lm = cd->lunarmonth; 
  209. if ( lm < 0 ) 
  210. if ( lm != -im ) 
  211. return 2; 
  212. else if ( lm < 1 || lm > 12 ) 
  213. return 2; 
  214. if ( im != 0 ) 
  215. if ( lm > im ) 
  216. lm++; 
  217. else if ( lm == -im ) 
  218. lm = im + 1; 
  219. lm--; 
  220. if ( cd->lunardate > lunarcal[y].monthdays[lm] + 29 ) 
  221. return 3; 
  222. acc = lunarcal[y].basedays; 
  223. for ( i=0; i acc += lunarcal[y].monthdays[i] + 29; 
  224. acc += cd->lunardate; 
  225. leap = getleap( cd->lunaryear ); 
  226. for ( i=13; i>=0; i-- ) 
  227. if ( acc > solardays[leap][i] ) 
  228. break
  229. cd->solardate = acc - solardays[leap][i]; 
  230. if ( i <= 11 ) 
  231. cd->solaryear = cd->lunaryear; 
  232. cd->solarmonth = i + 1; 
  233. else 
  234. cd->solaryear = cd->lunaryear + 1; 
  235. cd->solarmonth = i - 11; 
  236. leap = getleap( cd->solaryear ); 
  237. y = cd->solaryear - firstyear; 
  238. acc = solardays[leap][cd->solarmonth-1] + cd->solardate; 
  239. cd->weekday = ( acc + lunarcal[y].baseweekday ) % 7; 
  240. kc = acc + lunarcal[y].basekanchih; 
  241. cd->kan = kc % 10; 
  242. cd->chih = kc % 12; 
  243. return 0; 

(感谢各位作者)

文献:
1、http://www.25175.com/200609/25175/25175_html/2006-11/936.html
2、http://hi.baidu.com/wangleiit/blog/item/d2ef51088122bf910b7b827c.html
3、http://www.supesoft.com/ArticleDisp.asp?ID=4618
4、http://www.cnblogs.com/panjiwen/archive/2006/02/06/326159.html
5、http://www.taoshaw.com/taoshaw/article.asp?id=1494
6、http://www.pcjx.com/Dotnet/C/208963.html
7、http://study.feloo.com/gaokao_news.do?infoID=50354

 

你可能感兴趣的:(ASP,.NET,VC#,JavaScript)