公历转农历

转载 2006年06月12日 15:03:00

/*------------农历转换函数-----------*/
char *GetDayOf(PSYSTEMTIME pSt)

 /*天干名称*/
 const char *cTianGan[] = {"甲","乙","丙","丁","戊","己","庚","辛","壬","癸"};
 /*地支名称*/
 const char *cDiZhi[] = {"子","丑","寅","卯","辰","巳","午","未","申","酉","戌","亥"};
 /*属相名称*/
 const char *cShuXiang[] = {"鼠","牛","虎","兔","龙","蛇","马","羊","猴","鸡","狗","猪"};
 /*农历日期名*/
 const char *cDayName[] = {"*","初一","初二","初三","初四","初五",
       "初六","初七","初八","初九","初十","十一","十二","十三","十四","十五","十六","十","十八","十九","二十","廿一","廿二","廿三","廿四","廿五","廿六","廿七","廿八","廿九","三十"};
 /*农历月份名*/
 const char *cMonName[] = {"*","正","二","三","四","五","六","七","八","九","十","十一","腊"};

 /*公历每月前面的天数*/
 const int wMonthAdd[12] = {0,31,59,90,120,151,181,212,243,273,304,334};
 /*农历数据*/
 const int wNongliData[100] = {2635,333387,1701,1748,267701,694,2391,133423,1175,396438
       ,3402,3749,331177,1453,694,201326,2350,465197,3221,3402
       ,400202,2901,1386,267611,605,2349,137515,2709,464533,1738
       ,2901,330421,1242,2651,199255,1323,529706,3733,1706,398762
       ,2741,1206,267438,2647,1318,204070,3477,461653,1386,2413
       ,330077,1197,2637,268877,3365,531109,2900,2922,398042,2395
       ,1179,267415,2635,661067,1701,1748,398772,2742,2391,330031
       ,1175,1611,200010,3749,527717,1452,2742,332397,2350,3222
       ,268949,3402,3493,133973,1386,464219,605,2349,334123,2709
       ,2890,267946,2773,592565,1210,2651,395863,1323,2707,265877};
 static int wCurYear,wCurMonth,wCurDay;
 static int nTheDate,nIsEnd,m,k,n,i,nBit;
 TCHAR szNongli[30], szNongliDay[10],szShuXiang[10];
 /*---取当前公历年、月、日---*/
 wCurYear = pSt->wYear;
 wCurMonth = pSt->wMonth;
 wCurDay = pSt->wDay;
 /*---计算到初始时间1921年2月8日的天数:1921-2-8(正月初一)---*/
 nTheDate = (wCurYear - 1921) * 365 + (wCurYear - 1921) / 4 + wCurDay + wMonthAdd[wCurMonth - 1] - 38;
 if((!(wCurYear % 4)) && (wCurMonth > 2))
  nTheDate = nTheDate + 1;


 /*--计算农历天干、地支、月、日---*/
 nIsEnd = 0;
 m = 0;
 while(nIsEnd != 1)
 {
  if(wNongliData[m] < 4095)
   k = 11;
  else
   k = 12;
  n = k;
  while(n>=0)
  {
   //获取wNongliData(m)的第n个二进制位的值
   nBit = wNongliData[m];
   for(i=1;i<n+1;i++)
    nBit = nBit/2;

   nBit = nBit % 2;

   if (nTheDate <= (29 + nBit))
   {
    nIsEnd = 1;
    break;
   }

   nTheDate = nTheDate - 29 - nBit;
   n = n - 1;
  }
  if(nIsEnd)
   break;
  m = m + 1;
 }
 wCurYear = 1921 + m;
 wCurMonth = k - n + 1;
 wCurDay = nTheDate;
 if (k == 12)
 {
  if (wCurMonth == wNongliData[m] / 65536 + 1)
   wCurMonth = 1 - wCurMonth;
  else if (wCurMonth > wNongliData[m] / 65536 + 1)
   wCurMonth = wCurMonth - 1;
 }


 /*--生成农历天干、地支、属相 ==> wNongli--*/
 wsprintf(szShuXiang,"%s",cShuXiang[((wCurYear - 4) % 60) % 12]);
 wsprintf(szNongli,"%s(%s%s)年",szShuXiang,cTianGan[((wCurYear - 4) % 60) % 10],cDiZhi[((wCurYear - 4) % 60) % 12]);


 /*--生成农历月、日 ==> wNongliDay--*/
 if (wCurMonth < 1)
  wsprintf(szNongliDay,"闰%s",cMonName[-1 * wCurMonth]);
 else
  strcpy(szNongliDay,cMonName[wCurMonth]);


 strcat(szNongliDay,"月");
 strcat(szNongliDay,cDayName[wCurDay]);
 return strcat(szNongli,szNongliDay);


}

相关文章推荐

工具类_公历农历互转_同时支持星期的查询

写了一个工具类DateTransfer,提供在1900-2099年的以下功能: 1.公历转换为农历 2.农历转换为公历 3.公历日期获取星期 4.农历日期获取星期 5.获取指定农历年月的一个月的字符串...
  • finnfu
  • finnfu
  • 2015年05月08日 22:26
  • 962

公历转农历算法(C语言)

#include #include #include unsigned int LunarCalendarDay; unsigned int LunarCalendarTable[199] =...

java版公历转农历

package com.ljtools; import java.text.SimpleDateFormat; import java.util.Calendar; import java.ut...

SQL Server公历转农历函数

--创建农历日期函数   if object_id('fn_GetLunar') is not null     drop function fn_GetLunar go  create functi...

【转帖】试论公历与农历的比较

试论公历与农历的比较 崔  奕 来源(未搜索到原始帖):http://club.excelhome.net/forum.php?mod=viewthread&tid=592122&page...
  • mostone
  • mostone
  • 2012年10月18日 17:01
  • 1215

阳历(公历)转农历

网上找了一些阳历转农历的代码,但总是有些对不上。 参照百度万年历和好记星的日历,实现了一下1900-2099年之间的阳历转农历。 #include using namespace std; ...
  • problc
  • problc
  • 2011年08月23日 15:47
  • 1001

C# 阳历转阴历函数 公历转农历函数

using System;using System.Collections.Generic;using System.Linq;using System.Web;/// ///dateToYL 的摘要...

公历转农历的程序(代码转载于网络)

/*------------农历转换函数-----------*/ void Window::get_chinese_calendar(QDate english_calendar, QString...

【Java开发】中国的公历转农历-工具类

直接工具类: /** * */ package com.jy.common.utils; import java.text.SimpleDateFormat; import java.uti...
  • hj7jay
  • hj7jay
  • 2016年08月20日 14:06
  • 762

c#版公历转农历

using System; namespace LjTools { /// /// 公历转农历算法 /// public class ChinaDate { ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:公历转农历
举报原因:
原因补充:

(最多只允许输入30个字)