導航:首頁 > 源碼編譯 > java農歷演算法

java農歷演算法

發布時間:2022-09-27 12:13:16

① 求java農歷公歷互轉演算法,發到[email protected],記住 是 公歷農歷互轉演算法,發送前請先自己檢測20個日期

星座是按陽歷(公歷)日期劃分的.

白羊座:3月21日 - 4月20日

金牛座:4月21日 - 5月21日

雙子座:5月22日 - 6月21日

巨蟹座:6月22日 - 7月22日

獅子座:7月23日 - 8月23日

處女座:8月24日 - 9月23日

天秤座:9月24日 - 10月23日

天蠍座:10月24日 - 11月22日

射手座:11月23日 - 12月21日

魔羯座:12月22日 - 1月20日

水瓶座:1月21日 - 2月19日

雙魚座:2月20日 - 3月20日

你1996年農歷11月17日出生 就是 1996年新歷的12月27日 。 你屬魔羯座。

② java怎麼取得農歷的節日

public class Lunar
{
private int year;
private int month;
private int day;
private boolean leap;
final static String chineseNumber[] =
{ "一", "二", "三", "四", "五", "六", "七", "八", "九", "十", "十一", "十二" };
final static String Big_Or_Small[] =
{ "大", "小", "大", "小", "大", "小", "大", "大", "小", "大", "小", "大" };
private String[] LunarHolDayName =
{ "小寒", "大寒", "立春", "雨水", "驚蟄", "春分", "清明", "穀雨", "立夏", "小滿", "芒種", "夏至",
"小暑", "大暑", "立秋", "處暑", "白露", "秋分", "寒露", "霜降", "立冬", "小雪", "大雪",
"冬至" };

static SimpleDateFormat chineseDateFormat = new SimpleDateFormat(
" yyyy年MM月dd日 ");
final static long[] lunarInfo = new long[]
{ 0x04bd8, 0x04ae0, 0x0a570, 0x054d5, 0x0d260, 0x0d950, 0x16554, 0x056a0,
0x09ad0, 0x055d2, 0x04ae0, 0x0a5b6, 0x0a4d0, 0x0d250, 0x1d255,
0x0b540, 0x0d6a0, 0x0ada2, 0x095b0, 0x14977, 0x04970, 0x0a4b0,
0x0b4b5, 0x06a50, 0x06d40, 0x1ab54, 0x02b60, 0x09570, 0x052f2,
0x04970, 0x06566, 0x0d4a0, 0x0ea50, 0x06e95, 0x05ad0, 0x02b60,
0x186e3, 0x092e0, 0x1c8d7, 0x0c950, 0x0d4a0, 0x1d8a6, 0x0b550,
0x056a0, 0x1a5b4, 0x025d0, 0x092d0, 0x0d2b2, 0x0a950, 0x0b557,
0x06ca0, 0x0b550, 0x15355, 0x04da0, 0x0a5d0, 0x14573, 0x052d0,
0x0a9a8, 0x0e950, 0x06aa0, 0x0aea6, 0x0ab50, 0x04b60, 0x0aae4,
0x0a570, 0x05260, 0x0f263, 0x0d950, 0x05b57, 0x056a0, 0x096d0,
0x04dd5, 0x04ad0, 0x0a4d0, 0x0d4d4, 0x0d250, 0x0d558, 0x0b540,
0x0b5a0, 0x195a6, 0x095b0, 0x049b0, 0x0a974, 0x0a4b0, 0x0b27a,
0x06a50, 0x06d40, 0x0af46, 0x0ab60, 0x09570, 0x04af5, 0x04970,
0x064b0, 0x074a3, 0x0ea50, 0x06b58, 0x055c0, 0x0ab60, 0x096d5,
0x092e0, 0x0c960, 0x0d954, 0x0d4a0, 0x0da50, 0x07552, 0x056a0,
0x0abb7, 0x025d0, 0x092d0, 0x0cab5, 0x0a950, 0x0b4a0, 0x0baa4,
0x0ad50, 0x055d9, 0x04ba0, 0x0a5b0, 0x15176, 0x052b0, 0x0a930,
0x07954, 0x06aa0, 0x0ad50, 0x05b52, 0x04b60, 0x0a6e6, 0x0a4e0,
0x0d260, 0x0ea65, 0x0d530, 0x05aa0, 0x076a3, 0x096d0, 0x04bd7,
0x04ad0, 0x0a4d0, 0x1d0b6, 0x0d250, 0x0d520, 0x0dd45, 0x0b5a0,
0x056d0, 0x055b2, 0x049b0, 0x0a577, 0x0a4b0, 0x0aa50, 0x1b255,
0x06d20, 0x0ada0 };

// ====== 傳回農歷 y年的總天數
final private static int yearDays(int y)
{
int i, sum = 348;
for (i = 0x8000; i > 0x8; i >>= 1)
{
if ((lunarInfo[y - 1900] & i) != 0)
sum += 1;
}
return (sum + leapDays(y));
}

// ====== 傳回農歷 y年閏月的天數
final private static int leapDays(int y)
{
if (leapMonth(y) != 0)
{
if ((lunarInfo[y - 1900] & 0x10000) != 0)
return 30;
else
return 29;
}
else
return 0;
}

// ====== 傳回農歷 y年閏哪個月 1-12 , 沒閏傳回 0
final private static int leapMonth(int y)
{
return (int) (lunarInfo[y - 1900] & 0xf);
}

// ====== 傳回農歷 y年m月的總天數
final private static int monthDays(int y, int m)
{
if ((lunarInfo[y - 1900] & (0x10000 >> m)) == 0)
return 29;
else
return 30;
}

// ====== 傳回農歷 y年的生肖
final public String animalsYear()
{
final String[] Animals = new String[]
{ "鼠", "牛", "虎", "兔", "龍", "蛇", "馬", "羊", "猴", "雞", "狗", "豬" };
return Animals[(year - 4) % 12];
}

// ====== 傳入 月日的offset 傳回干支, 0=甲子
final private static String cyclicalm(int num)
{
final String[] Gan = new String[]
{ "甲", "乙", "丙", "丁", "戊", "己", "庚", "辛", "壬", "癸" };
final String[] Zhi = new String[]
{ "子", "丑", "寅", "卯", "辰", "巳", "午", "未", "申", "酉", "戌", "亥" };
return (Gan[num % 10] + Zhi[num % 12]);
}

// ====== 傳入 offset 傳回干支, 0=甲子
final public String cyclical()
{
int num = year - 1900 + 36;
return (cyclicalm(num));
}

/** */
/**
* 傳出y年m月d日對應的農歷. yearCyl3:農歷年與1864的相差數 ? monCyl4:從1900年1月31日以來,閏月數
* dayCyl5:與1900年1月31日相差的天數,再加40 ?
*
* @param cal
* @return
*/
public Lunar(Calendar cal)
{
// cal.add(cal.get(Calendar.DAY_OF_MONTH),1);
@SuppressWarnings(" unused ")
int yearCyl, monCyl, dayCyl;
int leapMonth = 0;
Date baseDate = null;
try
{
baseDate = chineseDateFormat.parse(" 1900年1月31日 ");
}
catch (ParseException e)
{
e.printStackTrace(); // To change body of catch statement use
// Options | File Templates.
}

// 求出和1900年1月31日相差的天數
int offset = (int) ((cal.getTime().getTime() - baseDate.getTime()) / 86400000L);
dayCyl = offset + 40;
monCyl = 14;

// 用offset減去每農歷年的天數
// 計算當天是農歷第幾天
// i最終結果是農歷的年份
// offset是當年的第幾天
int iYear, daysOfYear = 0;
for (iYear = 1900; iYear < 2050 && offset > 0; iYear++)
{
daysOfYear = yearDays(iYear);
offset -= daysOfYear;
monCyl += 12;
}
if (offset < 0)
{
offset += daysOfYear;
iYear--;
monCyl -= 12;
}
// 農歷年份
year = iYear;

yearCyl = iYear - 1864;
leapMonth = leapMonth(iYear); // 閏哪個月,1-12
leap = false;

// 用當年的天數offset,逐個減去每月(農歷)的天數,求出當天是本月的第幾天
int iMonth, daysOfMonth = 0;
for (iMonth = 1; iMonth < 13 && offset > 0; iMonth++)
{
// 閏月
if (leapMonth > 0 && iMonth == (leapMonth + 1) && !leap)
{
--iMonth;
leap = true;
daysOfMonth = leapDays(year);
}
else
daysOfMonth = monthDays(year, iMonth);

offset -= daysOfMonth;
// 解除閏月
if (leap && iMonth == (leapMonth + 1))
leap = false;
if (!leap)
monCyl++;
}
// offset為0時,並且剛才計算的月份是閏月,要校正
if (offset == 0 && leapMonth > 0 && iMonth == leapMonth + 1)
{
if (leap)
{
leap = false;
}
else
{
leap = true;
--iMonth;
--monCyl;
}
}
// offset小於0時,也要校正
if (offset < 0)
{
offset += daysOfMonth;
--iMonth;
--monCyl;
}
month = iMonth;
day = offset + 1;
}

public static String getChinaDayString(int day)
{
String chineseTen[] =
{ "初", "十", "廿", "卅" };
int n = day % 10 == 0 ? 9 : day % 10 - 1;
if (day > 30)
return "";
if (day == 10)
return "初十";
else
return chineseTen[day / 10] + chineseNumber[n];
}

public String toString()
{
return /* cyclical() + "年" + */(leap ? "閏" : "")
+ chineseNumber[month - 1] + "月" + getChinaDayString(day);
}

public String numeric_md()
{// 返回阿拉伯數字的陰歷日期
String temp_day;
String temp_mon;
temp_mon = month < 10 ? "0" + month : "" + month;
temp_day = day < 10 ? "0" + day : "" + day;

return temp_mon + temp_day;
}

public String get_month()
{// 返回陰歷的月份
return chineseNumber[month - 1];
}

public String get_date()
{// 返回陰歷的天
return getChinaDayString(day);
}

public String get_Big_Or_Small()
{// 返回的月份的大或小
return Big_Or_Small[month - 1];
}

}

③ java中calendar獲取的時間是陰歷還是陽歷

獲取的是陽歷,補充一點,一般都是用陽歷的
陽歷也叫公歷,來源於西方。比如算星座時、就是按照陽歷(公歷)計算的。
陰歷也叫農歷,來源於我們中國。
比如我們俗稱的八月十五中秋節、清明節、七夕、春節、就是按照農歷來計算的。而元旦、和西方的情人節(2.14)和聖誕節、國慶節、建軍節、黨的生日、都是按照公歷來計算的。

他們的主要區別就在於陽歷是國際通用的,而農歷是我們中國特有的。

編程語言是國外的,怎麼可能用來獲取我們中國特有的時間呢

④ Java怎樣編程實現農歷和陽歷轉換

public class TestNongLi {
public static void main(String[] args) {
// 調用農歷日期轉換陽歷日期方法
System.out.println(ChineseCalendar.sCalendarLundarToSolar(2008, 1, 1));
}
}
// 自定義日歷類
class ChineseCalendar {
// Array lIntLunarDay is stored in the monthly day information in every year from 1901 to 2100 of the lunar calendar,
// The lunar calendar can only be 29 or 30 days every month, express with 12(or 13) pieces of binary bit in one year,
// it is 30 days for 1 form in the corresponding location , otherwise it is 29 days
private static final int[] iLunarmont

⑤ java萬年歷

別人寫的 借花獻佛

萬年歷的 但是不實現農歷

如何計算某一天是星期幾?
slowtiger 發表於 2005-10-11 21:43:00
如何計算某一天是星期幾?
—— 蔡勒(Zeller)公式
歷史上的某一天是星期幾?未來的某一天是星期幾?關於這個問題,有很多計算公式(兩個通用計算公式和一些分段計算公式),其中最著名的是蔡勒(Zeller)公式。
即w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1

公式中的符號含義如下,w:星期;c:世紀-1;y:年(兩位數);m:月(m大於等於3,小於等於14,即在蔡勒公式中,某年的1、2月要看作上一年的13、14月來計算,比如2003年1月1日要看作2002年的13月1日來計算);d:日;[ ]代表取整,即只要整數部分。(C是世紀數減一,y是年份後兩位,M是月份,d是日數。

1月和2月要按上一年的13月和 14月來算,這時C和y均按上一年取值。)

算出來的W除以7,余數是幾就是星期幾。如果余數是0,則為星期日。

以2049年10月1日(100周年國慶)為例,用蔡勒(Zeller)公式進行計算,過程如下:
蔡勒(Zeller)公式:w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1
=49+[49/4]+[20/4]-2×20+[26× (10+1)/10]+1-1
=49+[12.25]+5-40+[28.6]
=49+12+5-40+28
=54 (除以7餘5)
即2049年10月1日(100周年國慶)是星期5。

你的生日(出生時、今年、明年)是星期幾?不妨試一試。

不過,以上公式只適合於1582年10月15日之後的情形(當時的羅馬教皇將愷撒大帝制訂的儒略歷修改成格里歷,即今天使用的公歷)。

過程的推導:(對推理不感興趣的可略過不看)

星期制度是一種有古老傳統的制度。據說因為《聖經·創世紀》中規定上帝用了六
天時間創世紀,第七天休息,所以人們也就以七天為一個周期來安排自己的工作和生
活,而星期日是休息日。從實際的角度來講,以七天為一個周期,長短也比較合適。所
以盡管中國的傳統工作周期是十天(比如王勃《滕王閣序》中說的「十旬休暇」,即是
指官員的工作每十日為一個周期,第十日休假),但後來也採取了西方的星期制度。

在日常生活中,我們常常遇到要知道某一天是星期幾的問題。有時候,我們還想知
道歷史上某一天是星期幾。通常,解決這個方法的有效辦法是看日歷,但是我們總不會
隨時隨身帶著日歷,更不可能隨時隨身帶著幾千年的萬年歷。假如是想在計算機編程中
計算某一天是星期幾,預先把一本萬年歷存進去就更不現實了。這時候是不是有辦法通
過什麼公式,從年月日推出這一天是星期幾呢?

答案是肯定的。其實我們也常常在這樣做。我們先舉一個簡單的例子。比如,知道
了2004年5月1日是星期六,那麼2004年5月31日「世界無煙日」是星期幾就不難推算出
來。我們可以掰著指頭從1日數到31日,同時數星期,最後可以數出5月31日是星期一。
其實運用數學計算,可以不用掰指頭。我們知道星期是七天一輪回的,所以5月1日是星
期六,七天之後的5月8日也是星期六。在日期上,8-1=7,正是7的倍數。同樣,5月15
日、5月22日和5月29日也是星期六,它們的日期和5月1日的差值分別是14、21和28,也
都是7的倍數。那麼5月31日呢?31-1=30,雖然不是7的倍數,但是31除以7,余數為2,
這就是說,5月31日的星期,是在5月1日的星期之後兩天。星期六之後兩天正是星期一。

這個簡單的計算告訴我們計算星期的一個基本思路:首先,先要知道在想算的日子
之前的一個確定的日子是星期幾,拿這一天做為推算的標准,也就是相當於一個計算的
「原點」。其次,知道想算的日子和這個確定的日子之間相差多少天,用7除這個日期
的差值,余數就表示想算的日子的星期在確定的日子的星期之後多少天。如果余數是
0,就表示這兩天的星期相同。顯然,如果把這個作為「原點」的日子選為星期日,那
么余數正好就等於星期幾,這樣計算就更方便了。

但是直接計算兩天之間的天數,還是不免繁瑣。比如1982年7月29日和2004年5月
1日之間相隔7947天,就不是一下子能算出來的。它包括三段時間:一,1982年7月29
日以後這一年的剩餘天數;二,1983-2003這二十一個整年的全部天數;三,從2004年
元旦到5月1日經過的天數。第二段比較好算,它等於21*365+5=7670天,之所以要加
5,是因為這段時間內有5個閏年。第一段和第三段就比較麻煩了,比如第三段,需要把
5月之前的四個月的天數累加起來,再加上日期值,即31+29+31+30+1=122天。同理,第
一段需要把7月之後的五個月的天數累加起來,再加上7月剩下的天數,一共是155天。
所以總共的相隔天數是122+7670+155=7947天。

仔細想想,如果把「原點」日子的日期選為12月31日,那麼第一段時間也就是一個
整年,這樣一來,第一段時間和第二段時間就可以合並計算,整年的總數正好相當於兩
個日子的年份差值減一。如果進一步把「原點」日子選為公元前1年12月31日(或者天文
學家所使用的公元0年12月31日),這個整年的總數就正好是想算的日子的年份減一。這
樣簡化之後,就只須計算兩段時間:一,這么多整年的總天數;二,想算的日子是這一
年的第幾天。巧的是,按照公歷的年月設置,這樣反推回去,公元前1年12月31日正好是
星期日,也就是說,這樣算出來的總天數除以7的余數正好是星期幾。那麼現在的問題就
只有一個:這么多整年裡面有多少閏年。這就需要了解公歷的置閏規則了。

我們知道,公歷的平年是365天,閏年是366天。置閏的方法是能被4整除的年份在
2月加一天,但能被100整除的不閏,能被400整除的又閏。因此,像1600、2000、2400
年都是閏年,而1700、1800、1900、2100年都是平年。公元前1年,按公歷也是閏年。

因此,對於從公元前1年(或公元0年)12月31日到某一日子的年份Y之間的所有整年
中的閏年數,就等於

[(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400],

[...]表示只取整數部分。第一項表示需要加上被4整除的年份數,第二項表示需要去掉
被100整除的年份數,第三項表示需要再加上被400整除的年份數。之所以Y要減一,這
樣,我們就得到了第一個計算某一天是星期幾的公式:

W = (Y-1)*365 + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + D. (1)

其中D是這個日子在這一年中的累積天數。算出來的W就是公元前1年(或公元0年)12月
31日到這一天之間的間隔日數。把W用7除,余數是幾,這一天就是星期幾。比如我們來
算2004年5月1日:

W = (2004-1)*365 + [(2004-1)/4] - [(2004-1)/100] + [(2004-1)/400] +
(31+29+31+30+1)
= 731702,

731702 / 7 = 104528……6,余數為六,說明這一天是星期六。這和事實是符合的。

上面的公式(1)雖然很准確,但是計算出來的數字太大了,使用起來很不方便。仔
細想想,其實這個間隔天數W的用數僅僅是為了得到它除以7之後的余數。這啟發我們是
不是可以簡化這個W值,只要找一個和它余數相同的較小的數來代替,用數論上的術語
來說,就是找一個和它同餘的較小的正整數,照樣可以計算出准確的星期數。

顯然,W這么大的原因是因為公式中的第一項(Y-1)*365太大了。其實,

(Y-1)*365 = (Y-1) * (364+1)
= (Y-1) * (7*52+1)
= 52 * (Y-1) * 7 + (Y-1),

這個結果的第一項是一個7的倍數,除以7餘數為0,因此(Y-1)*365除以7的余數其實就
等於Y-1除以7的余數。這個關系可以表示為:

(Y-1)*365 ≡ Y-1 (mod 7).

其中,≡是數論中表示同餘的符號,mod 7的意思是指在用7作模數(也就是除數)的情
況下≡號兩邊的數是同餘的。因此,完全可以用(Y-1)代替(Y-1)*365,這樣我們就得到
了那個著名的、也是最常見到的計算星期幾的公式:

W = (Y-1) + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + D. (2)

這個公式雖然好用多了,但還不是最好用的公式,因為累積天數D的計算也比較麻
煩。是不是可以用月份數和日期直接計算呢?答案也是肯定的。我們不妨來觀察一下各
個月的日數,列表如下:

月 份:1月 2月 3月 4月 5月 6月 7月 8月 9月 10月 11月 12月
--------------------------------------------------------------------------
天 數: 31 28(29) 31 30 31 30 31 31 30 31 30 31

如果把這個天數都減去28(=4*7),不影響W除以7的余數值。這樣我們就得到另一張
表:

月 份:1月 2月 3月 4月 5月 6月 7月 8月 9月 10月 11月 12月
------------------------------------------------------------------------
剩餘天數: 3 0(1) 3 2 3 2 3 3 2 3 2 3
平年累積: 3 3 6 8 11 13 16 19 21 24 26 29
閏年累積: 3 4 7 9 12 14 17 20 22 25 27 30

仔細觀察的話,我們會發現除去1月和2月,3月到7月這五個月的剩餘天數值是3,2,3,2,
3;8月到12月這五個月的天數值也是3,2,3,2,3,正好是一個重復。相應的累積天數中,
後一月的累積天數和前一月的累積天數之差減去28就是這個重復。正是因為這種規律的
存在,平年和閏年的累積天數可以用數學公式很方便地表達:

╭ d; (當M=1)
D = { 31 + d; (當M=2) (3)
╰ [ 13 * (M+1) / 5 ] - 7 + (M-1) * 28 + d + i. (當M≥3)

其中[...]仍表示只取整數部分;M和d分別是想算的日子的月份和日數;平年i=0,閏年
i=1。對於M≥3的表達式需要說明一下:[13*(M+1)/5]-7算出來的就是上面第二個表中的
平年累積值,再加上(M-1)*28就是想算的日子的月份之前的所有月份的總天數。這是一
個很巧妙的辦法,利用取整運算來實現3,2,3,2,3的循環。比如,對2004年5月1日,有:

D = [ 13 * (5+1) / 5 ] - 7 + (5-1) * 28 + 1 + 1
= 122,

這正是5月1日在2004年的累積天數。

假如,我們再變通一下,把1月和2月當成是上一年的「13月」和「14月」,不僅仍
然符合這個公式,而且因為這樣一來,閏日成了上一「年」(一共有14個月)的最後一
天,成了d的一部分,於是平閏年的影響也去掉了,公式就簡化成:

D = [ 13 * (M+1) / 5 ] - 7 + (M-1) * 28 + d. (3≤M≤14) (4)

上面計算星期幾的公式,也就可以進一步簡化成:

W = (Y-1) + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + [ 13 * (M+1) / 5 ] - 7
+ (M-1) * 28 + d.

因為其中的-7和(M-1)*28兩項都可以被7整除,所以去掉這兩項,W除以7的余數不變,
公式變成:

W = (Y-1) + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + [ 13 * (M+1) / 5 ] + d.
(5)

當然,要注意1月和2月已經被當成了上一年的13月和14月,因此在計算1月和2月的日子
的星期時,除了M要按13或14算,年份Y也要減一。比如,2004年1月1日是星期四,用這
個公式來算,有:

W = (2003-1) + [(2003-1)/4] - [(2003-1)/100] + [(2003-1)/400] + [13*(13+1)/5]
+ 1
= 2002 + 500 - 20 + 5 + 36 + 1
= 2524;
2524 / 7 = 360……4.這和實際是一致的。

公式(5)已經是從年、月、日來算星期幾的公式了,但它還不是最簡練的,對於年
份的處理還有改進的方法。我們先來用這個公式算出每個世紀第一年3月1日的星期,列
表如下:

年份: 1(401,801,…,2001) 101(501,901,…,2101)
--------------------------------------------------------------------
星期: 4 2
====================================================================
年份:201(601,1001,…,2201) 301(701,1101,…,2301)
--------------------------------------------------------------------
星期: 0 5

可以看出,每隔四個世紀,這個星期就重復一次。假如我們把301(701,1101,…,2301)
年3月1日的星期數看成是-2(按數論中對余數的定義,-2和5除以7的余數相同,所以可
以做這樣的變換),那麼這個重復序列正好就是一個4,2,0,-2的等差數列。據此,我們
可以得到下面的計算每個世紀第一年3月1日的星期的公式:

W = (4 - C mod 4) * 2 - 4. (6)

式中,C是該世紀的世紀數減一,mod表示取模運算,即求余數。比如,對於2001年3月
1日,C=20,則:

W = (4 - 20 mod 4) * 2 - 4
= 8 - 4
= 4.

把公式(6)代入公式(5),經過變換,可得:

(Y-1) + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] ≡ (4 - C mod 4) * 2 - 1
(mod 7). (7)

因此,公式(5)中的(Y-1) + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400]這四項,在計算
每個世紀第一年的日期的星期時,可以用(4 - C mod 4) * 2 - 1來代替。這個公式寫
出來就是:

W = (4 - C mod 4) * 2 - 1 + [13 * (M+1) / 5] + d. (8)

有了計算每個世紀第一年的日期星期的公式,計算這個世紀其他各年的日期星期的公式
就很容易得到了。因為在一個世紀里,末尾為00的年份是最後一年,因此就用不著再考
慮「一百年不閏,四百年又閏」的規則,只須考慮「四年一閏」的規則。仿照由公式(1)
簡化為公式(2)的方法,我們很容易就可以從式(8)得到一個比公式(5)更簡單的計算任意
一天是星期幾的公式:

W = (4 - C mod 4) * 2 - 1 + (y-1) + [y/4] + [13 * (M+1) / 5] + d. (9)

式中,y是年份的後兩位數字。

如果再考慮到取模運算不是四則運算,我們還可以把(4 - C mod 4) * 2進一步改寫
成只含四則運算的表達式。因為世紀數減一C除以4的商數q和余數r之間有如下關系:

4q + r = C,

其中r即是 C mod 4,因此,有:

r = C - 4q
= C - 4 * [C/4]. (10)



(4 - C mod 4) * 2 = (4 - C + 4 * [C/4]) * 2
= 8 - 2C + 8 * [C/4]
≡ [C/4] - 2C + 1 (mod 7). (11)

把式(11)代入(9),得到:

W = [C/4] - 2C + y + [y/4] + [13 * (M+1) / 5] + d - 1. (12)

這個公式由世紀數減一、年份末兩位、月份和日數即可算出W,再除以7,得到的余數是
幾就表示這一天是星期幾,唯一需要變通的是要把1月和2月當成上一年的13月和14月,
C和y都按上一年的年份取值。因此,人們普遍認為這是計算任意一天是星期幾的最好的
公式。這個公式最早是由德國數學家克里斯蒂安·蔡勒(Christian Zeller, 1822-
1899)在1886年推導出的,因此通稱為蔡勒公式(Zeller』s Formula)。為方便口算,
式中的[13 * (M+1) / 5]也往往寫成[26 * (M+1) / 10]。

現在仍然讓我們來算2004年5月1日的星期,顯然C=20,y=4,M=5,d=1,代入蔡勒
公式,有:

W = [20/4] - 40 + 4 + 1 + [13 * (5+1) / 5] + 1 - 1
= -15.

注意負數不能按習慣的余數的概念求余數,只能按數論中的余數的定義求余。為了方便
計算,我們可以給它加上一個7的整數倍,使它變為一個正數,比如加上70,得到55。
再除以7,餘6,說明這一天是星期六。這和實際是一致的,也和公式(2)計算所得的結
果一致。

最後需要說明的是,上面的公式都是基於公歷(格里高利歷)的置閏規則來考慮
的。對於儒略歷,蔡勒也推出了相應的公式是:

W = 5 - C + y + [y/4] + [13 * (M+1) / 5] + d - 1. (13)

========================================
(2005-10-20 22:25:00) --------(4575252)
計算任何一天是星期幾的幾種演算法
近日在論壇上看到有人在問星期演算法,特別整理了一下,這些演算法都是從網上搜索而來,演算法的實現是我在項目中寫的。希望對大家有所幫助。
一:常用公式

W = [Y-1] + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + D

Y是年份數,D是這一天在這一年中的累積天數,也就是這一天在這一年中是第幾天。

二:蔡勒(Zeller)公式

w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1

公式中的符號含義如下,w:星期;c:世紀;y:年(兩位數); m:月(m大於等於3,小於等於14,即在蔡勒公式中,某年的1、2月要看作上一年的13、14月來計算,比如2003年1月1日要看作2002年的13月1日來計算);d:日;[ ]代表取整,即只要整數部分。

相比於通用通用計算公式而言,蔡勒(Zeller)公式大大降低了計算的復雜度。

三:對蔡勒(Zeller)公式的改進

作者:馮思琮
相比於另外一個通用通用計算公式而言,蔡勒(Zeller)公式大大降低了計算的復雜度。不過,筆者給出的通用計算公式似乎更加簡潔(包括運算過程)。現將公式列於其下:
W=[y/4]+r (y/7)-2r(c/4)+m』+d

公式中的符號含義如下,r ( )代表取余,即只要余數部分;m』是m的修正數,現給出1至12月的修正數1』至12』如下:(1』,10』)=6;(2』,3』,11』)=2;(4』,7』)=5;5』=0;6』=3;8』=1;(9』,12』)=4(注意:在筆者給出的公式中,y為潤年時1』=5;2』=1)。其他符號與蔡勒(Zeller)公式中的含義相同。

四:基姆拉爾森計算公式

這個公式名稱是我給命名的,哈哈希望大家不要見怪。

W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400) mod 7

在公式中d表示日期中的日數,m表示月份數,y表示年數。

注意:在公式中有個與其他公式不同的地方:

把一月和二月看成是上一年的十三月和十四月,例:如果是2004-1-10則換算成:2003-13-10來代入公式計算。

⑥ 用java如何獲取當前時間的農歷

int weekDay = java.util.Calendar.getInstance().get(java.util.Calendar.DAY_OF_WEEK);
這個得出的是一個星期的第幾天。

⑦ 如何用java編寫帶時鍾的萬年歷代碼,萬年歷要有陰歷演算法

如圖:

來源:http://www.javaeye.com/topic/735220

如調試不成功,我把源碼發你信箱里

⑧ java萬年歷陰陽歷轉換

package test;

public class TestNongLi {
public static void main(String[] args) {
// 調用農歷日期轉換陽歷日期方法
System.out.println(ChineseCalendar.sCalendarLundarToSolar(2008, 1, 1));
}
}

// 自定義日歷類
class ChineseCalendar {

// Array lIntLunarDay is stored in the monthly day information in every year from 1901 to 2100 of the lunar calendar,
// The lunar calendar can only be 29 or 30 days every month, express with 12(or 13) pieces of binary bit in one year,
// it is 30 days for 1 form in the corresponding location , otherwise it is 29 days
private static final int[] iLunarMonthDaysTable = { 0x4ae0, 0xa570, 0x5268, 0xd260, 0xd950, 0x6aa8, 0x56a0, 0x9ad0, 0x4ae8,
0x4ae0, // 1910
0xa4d8, 0xa4d0, 0xd250, 0xd548, 0xb550, 0x56a0, 0x96d0, 0x95b0, 0x49b8, 0x49b0, // 1920
0xa4b0, 0xb258, 0x6a50, 0x6d40, 0xada8, 0x2b60, 0x9570, 0x4978, 0x4970, 0x64b0, // 1930
0xd4a0, 0xea50, 0x6d48, 0x5ad0, 0x2b60, 0x9370, 0x92e0, 0xc968, 0xc950, 0xd4a0, // 1940
0xda50, 0xb550, 0x56a0, 0xaad8, 0x25d0, 0x92d0, 0xc958, 0xa950, 0xb4a8, 0x6ca0, // 1950
0xb550, 0x55a8, 0x4da0, 0xa5b0, 0x52b8, 0x52b0, 0xa950, 0xe950, 0x6aa0, 0xad50, // 1960
0xab50, 0x4b60, 0xa570, 0xa570, 0x5260, 0xe930, 0xd950, 0x5aa8, 0x56a0, 0x96d0, // 1970
0x4ae8, 0x4ad0, 0xa4d0, 0xd268, 0xd250, 0xd528, 0xb540, 0xb6a0, 0x96d0, 0x95b0, // 1980
0x49b0, 0xa4b8, 0xa4b0, 0xb258, 0x6a50, 0x6d40, 0xada0, 0xab60, 0x9370, 0x4978, // 1990
0x4970, 0x64b0, 0x6a50, 0xea50, 0x6b28, 0x5ac0, 0xab60, 0x9368, 0x92e0, 0xc960, // 2000
0xd4a8, 0xd4a0, 0xda50, 0x5aa8, 0x56a0, 0xaad8, 0x25d0, 0x92d0, 0xc958, 0xa950, // 2010
0xb4a0, 0xb550, 0xb550, 0x55a8, 0x4ba0, 0xa5b0, 0x52b8, 0x52b0, 0xa930, 0x74a8, // 2020
0x6aa0, 0xad50, 0x4da8, 0x4b60, 0x9570, 0xa4e0, 0xd260, 0xe930, 0xd530, 0x5aa0, // 2030
0x6b50, 0x96d0, 0x4ae8, 0x4ad0, 0xa4d0, 0xd258, 0xd250, 0xd520, 0xdaa0, 0xb5a0, // 2040
0x56d0, 0x4ad8, 0x49b0, 0xa4b8, 0xa4b0, 0xaa50, 0xb528, 0x6d20, 0xada0, 0x55b0 // 2050
};

// Array iLunarLeapMonthTable preserves the lunar calendar leap month from 1901 to 2050,
// if it is 0 express not to have , every byte was stored for two years
private static final char[] iLunarLeapMonthTable = { 0x00, 0x50, 0x04, 0x00, 0x20, // 1910
0x60, 0x05, 0x00, 0x20, 0x70, // 1920
0x05, 0x00, 0x40, 0x02, 0x06, // 1930
0x00, 0x50, 0x03, 0x07, 0x00, // 1940
0x60, 0x04, 0x00, 0x20, 0x70, // 1950
0x05, 0x00, 0x30, 0x80, 0x06, // 1960
0x00, 0x40, 0x03, 0x07, 0x00, // 1970
0x50, 0x04, 0x08, 0x00, 0x60, // 1980
0x04, 0x0a, 0x00, 0x60, 0x05, // 1990
0x00, 0x30, 0x80, 0x05, 0x00, // 2000
0x40, 0x02, 0x07, 0x00, 0x50, // 2010
0x04, 0x09, 0x00, 0x60, 0x04, // 2020
0x00, 0x20, 0x60, 0x05, 0x00, // 2030
0x30, 0xb0, 0x06, 0x00, 0x50, // 2040
0x02, 0x07, 0x00, 0x50, 0x03 // 2050
};

// Array iSolarLunarTable stored the offset days
// in New Year of solar calendar and lunar calendar from 1901 to 2050;
private static final char[] iSolarLunarOffsetTable = { 49, 38, 28, 46, 34, 24, 43, 32, 21, 40, // 1910
29, 48, 36, 25, 44, 34, 22, 41, 31, 50, // 1920
38, 27, 46, 35, 23, 43, 32, 22, 40, 29, // 1930
47, 36, 25, 44, 34, 23, 41, 30, 49, 38, // 1940
26, 45, 35, 24, 43, 32, 21, 40, 28, 47, // 1950
36, 26, 44, 33, 23, 42, 30, 48, 38, 27, // 1960
45, 35, 24, 43, 32, 20, 39, 29, 47, 36, // 1970
26, 45, 33, 22, 41, 30, 48, 37, 27, 46, // 1980
35, 24, 43, 32, 50, 39, 28, 47, 36, 26, // 1990
45, 34, 22, 40, 30, 49, 37, 27, 46, 35, // 2000
23, 42, 31, 21, 39, 28, 48, 37, 25, 44, // 2010
33, 23, 41, 31, 50, 39, 28, 47, 35, 24, // 2020
42, 30, 21, 40, 28, 47, 36, 25, 43, 33, // 2030
22, 41, 30, 49, 37, 26, 44, 33, 23, 42, // 2040
31, 21, 40, 29, 47, 36, 25, 44, 32, 22, // 2050
};

static boolean bIsSolarLeapYear(int iYear) {
return ((iYear % 4 == 0) && (iYear % 100 != 0) || iYear % 400 == 0);
}

// The days in the month of solar calendar
static int iGetSYearMonthDays(int iYear, int iMonth) {
if ((iMonth == 1) || (iMonth == 3) || (iMonth == 5) || (iMonth == 7) || (iMonth == 8) || (iMonth == 10) || (iMonth == 12))
return 31;
else if ((iMonth == 4) || (iMonth == 6) || (iMonth == 9) || (iMonth == 11))
return 30;
else if (iMonth == 2) {
if (bIsSolarLeapYear(iYear))
return 29;
else
return 28;
} else
return 0;
}

// The offset days from New Year and the day when point out in solar calendar
static int iGetSNewYearOffsetDays(int iYear, int iMonth, int iDay) {
int iOffsetDays = 0;

for (int i = 1; i < iMonth; i++) {
iOffsetDays += iGetSYearMonthDays(iYear, i);
}
iOffsetDays += iDay - 1;

return iOffsetDays;
}

static int iGetLLeapMonth(int iYear) {
char iMonth = iLunarLeapMonthTable[(iYear - 1901) / 2];

if (iYear % 2 == 0)
return (iMonth & 0x0f);
else
return (iMonth & 0xf0) >> 4;
}

static int iGetLMonthDays(int iYear, int iMonth) {
int iLeapMonth = iGetLLeapMonth(iYear);
if ((iMonth > 12) && (iMonth - 12 != iLeapMonth) || (iMonth < 0)) {
System.out.println("Wrong month, ^_^ , i think you are want a -1, go to death!");
return -1;
}
if (iMonth - 12 == iLeapMonth) {
if ((iLunarMonthDaysTable[iYear - 1901] & (0x8000 >> iLeapMonth)) == 0)
return 29;
else
return 30;
}
if ((iLeapMonth > 0) && (iMonth > iLeapMonth))
iMonth++;
if ((iLunarMonthDaysTable[iYear - 1901] & (0x8000 >> (iMonth - 1))) == 0)
return 29;
else
return 30;
}

// Days in this year of lunar calendar
static int iGetLYearDays(int iYear) {
int iYearDays = 0;
int iLeapMonth = iGetLLeapMonth(iYear);

for (int i = 1; i < 13; i++)
iYearDays += iGetLMonthDays(iYear, i);
if (iLeapMonth > 0)
iYearDays += iGetLMonthDays(iYear, iLeapMonth + 12);
return iYearDays;
}

static int iGetLNewYearOffsetDays(int iYear, int iMonth, int iDay) {
int iOffsetDays = 0;
int iLeapMonth = iGetLLeapMonth(iYear);

if ((iLeapMonth > 0) && (iLeapMonth == iMonth - 12)) {
iMonth = iLeapMonth;
iOffsetDays += iGetLMonthDays(iYear, iMonth);
}

for (int i = 1; i < iMonth; i++) {
iOffsetDays += iGetLMonthDays(iYear, i);
if (i == iLeapMonth)
iOffsetDays += iGetLMonthDays(iYear, iLeapMonth + 12);
}
iOffsetDays += iDay - 1;

return iOffsetDays;
}

// The solar calendar is turned into the lunar calendar
static String sCalendarSolarToLundar(int iYear, int iMonth, int iDay) {
int iLDay, iLMonth, iLYear;
int iOffsetDays = iGetSNewYearOffsetDays(iYear, iMonth, iDay);
int iLeapMonth = iGetLLeapMonth(iYear);

if (iOffsetDays < iSolarLunarOffsetTable[iYear - 1901]) {
iLYear = iYear - 1;
iOffsetDays = iSolarLunarOffsetTable[iYear - 1901] - iOffsetDays;
iLDay = iOffsetDays;

for (iLMonth = 12; iOffsetDays > iGetLMonthDays(iLYear, iLMonth); iLMonth--) {
iLDay = iOffsetDays;
iOffsetDays -= iGetLMonthDays(iLYear, iLMonth);
}
if (0 == iLDay)
iLDay = 1;
else
iLDay = iGetLMonthDays(iLYear, iLMonth) - iOffsetDays + 1;
} else {
iLYear = iYear;
iOffsetDays -= iSolarLunarOffsetTable[iYear - 1901];
iLDay = iOffsetDays + 1;

for (iLMonth = 1; iOffsetDays >= 0; iLMonth++) {
iLDay = iOffsetDays + 1;
iOffsetDays -= iGetLMonthDays(iLYear, iLMonth);
if ((iLeapMonth == iLMonth) && (iOffsetDays > 0)) {
iLDay = iOffsetDays;
iOffsetDays -= iGetLMonthDays(iLYear, iLMonth + 12);
if (iOffsetDays <= 0) {
iLMonth += 12 + 1;
break;
}
}
}
iLMonth--;
}
return "" + iLYear + (iLMonth > 9 ? "" + iLMonth : "0" + iLMonth) + (iLDay > 9 ? "" + iLDay : "0" + iLDay);
}

// The lunar calendar is turned into the Solar calendar
static String sCalendarLundarToSolar(int iYear, int iMonth, int iDay) {
int iSYear, iSMonth, iSDay;
int iOffsetDays = iGetLNewYearOffsetDays(iYear, iMonth, iDay) + iSolarLunarOffsetTable[iYear - 1901];
int iYearDays = bIsSolarLeapYear(iYear) ? 366 : 365;

if (iOffsetDays >= iYearDays) {
iSYear = iYear + 1;
iOffsetDays -= iYearDays;
} else {
iSYear = iYear;
}
iSDay = iOffsetDays + 1;
for (iSMonth = 1; iOffsetDays >= 0; iSMonth++) {
iSDay = iOffsetDays + 1;
iOffsetDays -= iGetSYearMonthDays(iSYear, iSMonth);
}
iSMonth--;

return "" + iSYear + (iSMonth > 9 ? iSMonth + "" : "0" + iSMonth) + (iSDay > 9 ? iSDay + "" : "0" + iSDay);
}
}

// 自定義星期類
class Week {
int iWeek;

private String sWeek[] = { "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday" };

public Week() {
iWeek = 0;
}

public Week(int w) {
if ((w > 6) || (w < 0)) {
System.out.println("Week out of range, I think you want Sunday");
this.iWeek = 0;
} else
this.iWeek = w;
}

public String toString() {
return sWeek[iWeek];
}
}

// 自定義日期類
class MyDate {

public int iYear;

public int iMonth;

public int iDay;

private static int checkYear(int iYear) {
if ((iYear > 1901) && (iYear < 2050))
return iYear;
else {
System.out.println("The Year out of range, I think you want 1981");
return 1981;
}
}

public MyDate(int iYear, int iMonth, int iDay) {
this.iYear = checkYear(iYear);
this.iMonth = iMonth;
this.iDay = iDay;
}

public MyDate(int iYear, int iMonth) {
this.iYear = checkYear(iYear);
this.iMonth = iMonth;
this.iDay = 1;
}

public MyDate(int iYear) {
this.iYear = checkYear(iYear);
this.iMonth = 1;
this.iDay = 1;
}

public MyDate() {
this.iYear = 1981;
this.iMonth = 1;
this.iDay = 1;
}

public String toString() {
return "" + this.iYear + (this.iMonth > 9 ? "" + this.iMonth : "0" + this.iMonth)
+ (this.iDay > 9 ? "" + this.iDay : "0" + this.iDay);
}

public boolean equals(MyDate md) {
return ((md.iDay == this.iDay) && (md.iMonth == this.iMonth) && (md.iYear == this.iYear));
}
}

// 陽歷日期類,繼承自定義日期
class SolarDate extends MyDate {

private static int checkMonth(int iMonth) {
if (iMonth > 12) {
System.out.println("Month out of range, I think you want 12 ");
return 12;
} else if (iMonth < 1) {
System.out.println("Month out of range, I think you want 1 ");
return 1;
} else
return iMonth;
}

private static int checkDay(int iYear, int iMonth, int iDay) {
int iMonthDays = ChineseCalendar.iGetSYearMonthDays(iYear, iMonth);

if (iDay > iMonthDays) {
System.out.println("Day out of range, I think you want " + iMonthDays + " ");
return iMonthDays;
} else if (iDay < 1) {
System.out.println("Day out of range, I think you want 1 ");
return 1;
} else
return iDay;
}

public SolarDate(int iYear, int iMonth, int iDay) {
super(iYear);
this.iMonth = checkMonth(iMonth);
this.iDay = checkDay(this.iYear, this.iMonth, iDay);
}

public SolarDate(int iYear, int iMonth) {
super(iYear);
this.iMonth = checkMonth(iMonth);
}

public SolarDate(int iYear) {
super(iYear);
}

public SolarDate() {
super();
}

public String toString() {
return "" + this.iYear + (this.iMonth > 9 ? "-" + this.iMonth : "-0" + this.iMonth)
+ (this.iDay > 9 ? "-" + this.iDay : "-0" + this.iDay);
}

public Week toWeek() {
int iOffsetDays = 0;
for (int i = 1901; i < iYear; i++) {
if (ChineseCalendar.bIsSolarLeapYear(i))
iOffsetDays += 366;
else
iOffsetDays += 365;
}

iOffsetDays += ChineseCalendar.iGetSNewYearOffsetDays(iYear, iMonth, iDay);
return new Week((iOffsetDays + 2) % 7);
}

public LunarDate toLunarDate() {
int iYear, iMonth, iDay, iDate;
LunarDate ld;
iDate = Integer.parseInt(ChineseCalendar.sCalendarSolarToLundar(this.iYear, this.iMonth, this.iDay));
iYear = iDate / 10000;
iMonth = iDate % 10000 / 100;
iDay = iDate % 100;
ld = new LunarDate(iYear, iMonth, iDay);
return ld;
}
}

// 陰歷日期類,繼承自定義日期類
class LunarDate extends MyDate {

private String sChineseNum[] = { "零", "一", "二", "三", "四", "五", "六", "七", "八", "九", "十" };

private static int checkMonth(int iYear, int iMonth) {
if ((iMonth > 12) && (iMonth == ChineseCalendar.iGetLLeapMonth(iYear) + 12)) {
return iMonth;
} else if (iMonth > 12) {
System.out.println("Month out of range, I think you want 12 ");
return 12;
} else if (iMonth < 1) {
System.out.println("Month out of range, I think you want 1 ");
return 1;
} else
return iMonth;
}

private static int checkDay(int iYear, int iMonth, int iDay) {
int iMonthDays = ChineseCalendar.iGetLMonthDays(iYear, iMonth);

if (iDay > iMonthDays) {
System.out.println("Day out of range, I think you want " + iMonthDays + " ");
return iMonthDays;
} else if (iDay < 1) {
System.out.println("Day out of range, I think you want 1 ");
return 1;
} else
return iDay;
}

public LunarDate(int iYear, int iMonth, int iDay) {
super(iYear);
this.iMonth = checkMonth(this.iYear, iMonth);
this.iDay = checkDay(this.iYear, this.iMonth, iDay);
}

public LunarDate(int iYear, int iMonth) {
super(iYear);
this.iMonth = checkMonth(this.iYear, iMonth);
}

public LunarDate(int iYear) {
super(iYear);
}

public LunarDate() {
super();
}

public String toString() {
String sCalendar = "農歷";

sCalendar += sChineseNum[iYear / 1000] + sChineseNum[iYear % 1000 / 100] + sChineseNum[iYear % 100 / 10]
+ sChineseNum[iYear % 10] + "(" + toChineseEra() + ")年";
if (iMonth > 12) {
iMonth -= 12;
sCalendar += "閏";
}
if (iMonth == 12)
sCalendar += "臘月";
else if (iMonth == 11)
sCalendar += "冬月";
else if (iMonth == 1)
sCalendar += "正月";
else
sCalendar += sChineseNum[iMonth] + "月";
if (iDay > 29)
sCalendar += "三十";
else if (iDay > 20)
sCalendar += "二十" + sChineseNum[iDay % 20];
else if (iDay == 20)
sCalendar += "二十";
else if (iDay > 10)
sCalendar += "十" + sChineseNum[iDay % 10];
else
sCalendar += "初" + sChineseNum[iDay];

return sCalendar;
}

public CnWeek toWeek() {
int iOffsetDays = 0;
for (int i = 1901; i < iYear; i++)
iOffsetDays += ChineseCalendar.iGetLYearDays(i);

iOffsetDays += ChineseCalendar.iGetLNewYearOffsetDays(iYear, iMonth, iDay);
return new CnWeek((iOffsetDays + 2) % 7);
}

public ChineseEra toChineseEra() {
return new ChineseEra(iYear);
}

public SolarDate toSolarDate() {
int iYear, iMonth, iDay, iDate;
SolarDate sd;
iDate = Integer.parseInt(ChineseCalendar.sCalendarLundarToSolar(this.iYear, this.iMonth, this.iDay));
iYear = iDate / 10000;
iMonth = iDate % 10000 / 100;
iDay = iDate % 100;
sd = new SolarDate(iYear, iMonth, iDay);
return sd;
}
}

class CnWeek extends Week {

private String sCnWeek[] = { "日", "一", "二", "三", "四", "五", "六" };

public CnWeek() {
super();
}

public CnWeek(int iWeek) {
super(iWeek);
}

public String toString() {
return "星期" + sCnWeek[this.iWeek];
}
}

class ChineseEra {
int iYear;

String[] sHeavenlyStems = { "甲", "乙", "丙", "丁", "戊", "己", "庚", "辛", "壬", "癸" };

String[] sEarthlyBranches = { "子", "丑", "寅", "卯", "辰", "巳", "午", "未", "申", "酉", "戌", "亥" };

public ChineseEra() {
int iYear = 1981;
}

public ChineseEra(int iYear) {
if ((iYear < 2050) && (iYear > 1901))
this.iYear = iYear;
else
this.iYear = 1981;
}

public String toString() {
int temp;
temp = Math.abs(iYear - 1924);
return sHeavenlyStems[temp % 10] + sEarthlyBranches[temp % 12];
}
}

⑨ java中怎麼把公歷日期轉成農歷日期

Excel可以實現中陽歷日期轉換成陰歷日期,具體操作如下:

一、使用工具:excel2010

二、操作步驟:

1、假設A1為陽歷日期,B1為轉換後的陰歷日期值,點擊B1單元格輸入以下代碼:

=CHOOSE(MOD(YEAR(LEFT(TEXT(A1,"[$-130000]yyyy年mm月"&IF(LEN(--TEXT(A1,"[$-130000]dd"))=1,"初","")&"dd"),4)&"-"&MID(TEXT(A1,"[$-130000]yyyy年mm月"&IF(LEN(--TEXT(A1,"[$-130000]dd"))=1,"初","")&"dd"),6,2)&"-"&RIGHT(TEXT(A1,"[$-130000]yyyy年mm月"&IF(LEN(--TEXT(A1,"[$-130000]dd"))=1,"初","")&"dd"),2))-1900,10)+1,"庚","辛","壬","癸","甲","乙","丙","丁","戊","己")&CHOOSE(MOD(YEAR(LEFT(TEXT(A1,"[$-130000]yyyy年mm月"&IF(LEN(--TEXT(A1,"[$-130000]dd"))=1,"初","")&"dd"),4)&"-"&MID(TEXT(A1,"[$-130000]yyyy年mm月"&IF(LEN(--TEXT(A1,"[$-130000]dd"))=1,"初","")&"dd"),6,2)&"-"&RIGHT(TEXT(A1,"[$-130000]yyyy年mm月"&IF(LEN(--TEXT(A1,"[$-130000]dd"))=1,"初","")&"dd"),2))-1900,12)+1,"子","丑","寅","卯","辰","巳","午","未","申","酉","戌","亥")&TEXT(A1,"[dbnum1][$-130000]年m月"&IF(--TEXT(A1,"[$-130000]d")<11,"初","")&TEXT(A1,"[dbnum1][$-130000]d日"))

如圖:

⑩ java計算農歷日期

import java.util.Scanner;public class PrintCalendar { /**
* @param args
*/
public static void main(String[] args) {
System.out.println("******************歡 迎 使 用 萬 年 歷******************");
Scanner input = new Scanner(System.in);
System.out.print("\n請選擇年份: ");
int year = input.nextInt();
System.out.print("\n請選擇月份: ");
int month = input.nextInt();
System.out.println(); int days = 0; // 存儲當月的天數
boolean isRn;
/* 判斷是否是閏年 */
if (year % 4 == 0 && !(year % 100 == 0) || year % 400 == 0) { // 判斷是否為閏年
isRn = true; // 閏年
} else {
isRn = false;// 平年
} /* 計算輸入的年份之前的天數 */
int totalDays = 0;
for (int i = 1900; i < year; i++) {
/* 判斷閏年或平年,並進行天數累加 */
if (i % 4 == 0 && !(i % 100 == 0) || i % 400 == 0) { // 判斷是否為閏年
totalDays = totalDays + 366; // 閏年366天
} else {
totalDays = totalDays + 365; // 平年365天
}
} /* 計算輸入月份之前的天數 */
int beforeDays = 0;
for (int i = 1; i <= month; i++) {
switch (i) {
case 1:
case 3:
case 5:
case 7:
case 8:
case 10:
case 12:
days = 31;
break;
case 2:
if (isRn) {
days = 29;
} else {
days = 28;
}
break;
default:
days = 30;
break;
}
if (i < month) {
beforeDays = beforeDays + days;
}
}
totalDays = totalDays + beforeDays; // 距離1900年1月1日的天數 /* 計算星期幾 */
int firstDayOfMonth; // 存儲當月第一天是星期幾:星期日為0,星期一~星期六為1~6
int temp = 1 + totalDays % 7; // 從1900年1月1日推算
if (temp == 7) { // 求當月第一天
firstDayOfMonth = 0; // 周日
} else {
firstDayOfMonth = temp;
} /* 輸出日歷 */
System.out.println("星期日\t星期一\t星期二\t星期三\t星期四\t星期五\t星期六");
for (int nullNo = 0; nullNo < firstDayOfMonth; nullNo++) {
System.out.print("\t"); // 輸出空格
}
for (int i = 1; i <= days; i++) {
System.out.print(i + "\t");
if ((totalDays + i - 1) % 7 == 5) { // 如果當天為周六,輸出換行
System.out.println();
}
}
}
}

閱讀全文

與java農歷演算法相關的資料

熱點內容
程序員轉金融IT 瀏覽:832
黑馬程序員培訓效果如何 瀏覽:908
本地集成編譯 瀏覽:528
韓國電影哪個app可以看 瀏覽:701
玖月授權什麼app什麼梗 瀏覽:785
怎麼使用伺服器上的ip地址是什麼情況 瀏覽:750
手機密碼加密後怎麼解密 瀏覽:343
華為雲的伺服器的ip地址怎麼訪問不 瀏覽:367
webstormvue在線實時編譯生效 瀏覽:184
3225pdf 瀏覽:171
java中的常用類 瀏覽:394
安卓手機oppo反向色調怎麼開 瀏覽:138
羅志祥pdf 瀏覽:224
美國戰爭pdf 瀏覽:243
任務欄右擊如何顯示常用文件夾 瀏覽:100
海克斯康三次元編程 瀏覽:748
什麼app可以上門喂貓 瀏覽:889
老程序員抓彈幕 瀏覽:655
刷地鐵卡應該下個什麼app 瀏覽:154
安卓版谷歌瀏覽器為什麼用不了 瀏覽:505