電子開發(fā)網(wǎng)

電子開發(fā)網(wǎng)電子設(shè)計(jì) | 電子開發(fā)網(wǎng)Rss 2.0 會員中心 會員注冊
搜索: 您現(xiàn)在的位置: 電子開發(fā)網(wǎng) >> 電子開發(fā) >> 單片機(jī) >> 正文

C51農(nóng)歷轉(zhuǎn)換函數(shù)

作者:佚名    文章來源:本站原創(chuàng)    點(diǎn)擊數(shù):    更新時(shí)間:2010-10-4

char *GetDayOf(PSYSTEMTIME pSt) 

/*天干名稱*/ 
const char *cTianGan[] = {"甲","乙","丙","丁","戊","己","庚","辛","壬","癸"}; 
/*地支名稱*/ 
const char *cDiZhi[] = {"子","丑","寅","卯","辰","巳","午", 
"未","申","酉","戌","亥"}; 
/*屬相名稱*/ 
const char *cShuXiang[] = {"鼠","牛","虎","兔","龍","蛇", 
"馬","羊","猴","雞","狗","豬"}; 
/*農(nóng)歷日期名*/ 
const char *cDayName[] = {"*","初一","初二","初三","初四","初五", 
"初六","初七","初八","初九","初十", 
"十一","十二","十三","十四","十五", 
"十六","十七","十八","十九","二十", 
"廿一","廿二","廿三","廿四","廿五", 
"廿六","廿七","廿八","廿九","三十"}; 
/*農(nóng)歷月份名*/ 
const char *cMonName[] = {"*","正","二","三","四","五","六", 
"七","八","九","十","十一","臘"}; 

/*公歷每月前面的天數(shù)*/ 
const int wMonthAdd[12] = {0,31,59,90,120,151,181,212,243,273,304,334}; 
/*農(nóng)歷數(shù)據(jù)*/ 
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]; 
/*---取當(dāng)前公歷年、月、日---*/ 
wCurYear = pSt->wYear; 
wCurMonth = pSt->wMonth; 
wCurDay = pSt->wDay; 
/*---計(jì)算到初始時(shí)間1921年2月8日的天數(shù):1921-2-8(正月初一)---*/ 
nTheDate = (wCurYear - 1921) * 365 + (wCurYear - 1921) / 4 + wCurDay + wMonthAdd 
[wCurMonth - 1] - 38; 
if((!(wCurYear % 4)) && (wCurMonth > 2)) 
nTheDate = nTheDate + 1; 

/*--計(jì)算農(nóng)歷天干、地支、月、日---*/ 
nIsEnd = 0; 
m = 0; 
while(nIsEnd != 1) 

if(wNongliData[m] < 4095) 
k = 11; 
else 
k = 12; 
n = k; 
while(n>=0) 

//獲取wNongliData(m)的第n個(gè)二進(jì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; 

/*--生成農(nóng)歷天干、地支、屬相 ==> 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]); 

/*--生成農(nóng)歷月、日 ==> 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); 

Tags:單片機(jī),農(nóng)歷轉(zhuǎn)換函數(shù),程序  
責(zé)任編輯:admin
請文明參與討論,禁止漫罵攻擊,不要惡意評論、違禁詞語。 昵稱:
1分 2分 3分 4分 5分

還可以輸入 200 個(gè)字
[ 查看全部 ] 網(wǎng)友評論
關(guān)于我們 - 聯(lián)系我們 - 廣告服務(wù) - 友情鏈接 - 網(wǎng)站地圖 - 版權(quán)聲明 - 在線幫助 - 文章列表
返回頂部
刷新頁面
下到頁底
晶體管查詢
国产精品久久久久免费a∨| 手机1024看片| 亚洲老妈激情一区二区三区| 男女做爽爽免费视频| 国产一级毛片网站| 12至16末成年毛片高清| 在线视频www| 中文字幕国产在线观看| 日本成aⅴ人片日本伦| 久久精品国产亚洲AV蜜臀色欲| 日本丰满毛茸茸**| 久久久无码精品亚洲日韩蜜臀浪潮| 日韩美女va毛片在线播放| 亚洲福利一区二区| 欧美亚洲国产丝袜在线| 免费v片视频在线观看视频| 洗澡被王总干好舒服小说| 人妻少妇中文字幕乱码| 福利视频导航大全| 国产V片在线播放免费无码| 被合租粗糙室友到哭| 国产真实伦偷精品| 97精品伊人久久大香线蕉| 天堂va在线高清一区| 一本一道久久a久久精品综合| 成人看免费一级毛片| 久久最近最新中文字幕大全| 无遮挡又黄又爽又色的动态图1000| 久久久久久久久久国产精品免费 | 国产一区二区三区高清视频 | 欧美精品福利视频| 亚洲精品一卡2卡3卡四卡乱码| 欧美人与动人物姣配xxxx| 亚洲入口无毒网址你懂的| 日韩A无V码在线播放| 亚洲欧美日韩国产精品一区 | 小小影视日本动漫观看免费| 久久国产精品一区免费下载| 日本精品www色| 久久综合九色综合网站| 日韩亚洲欧美综合|