zoukankan      html  css  js  c++  java
  • 一个阴历阳历互相转化的类(C#源码)

    1. /// <summary>
    2. /// 中国日历信息实体类
    3. /// cncxz(虫虫) 2007-2-9
    4. /// </summary>
    5. public sealed class ChineseCalendarInfo  
    6. {  
    7. private DateTime m_SolarDate;  
    8. private int m_LunarYear, m_LunarMonth, m_LunarDay;  
    9. private bool m_IsLeapMonth = false;  
    10. private string m_LunarYearSexagenary = null, m_LunarYearAnimal = null;  
    11. private string m_LunarYearText = null, m_LunarMonthText = null, m_LunarDayText = null;  
    12. private string m_SolarWeekText = null, m_SolarConstellation = null, m_SolarBirthStone = null;  
    13.     #region 构造函数
    14. public ChineseCalendarInfo()  
    15.         : this(DateTime.Now.Date)  
    16.     {  
    17.     }  
    18. /// <summary>
    19. /// 从指定的阳历日期创建中国日历信息实体类
    20. /// </summary>
    21. /// <param name="date">指定的阳历日期</param>
    22. public ChineseCalendarInfo(DateTime date)  
    23.     {  
    24.         m_SolarDate = date;  
    25.         LoadFromSolarDate();  
    26.     }  
    27. private void LoadFromSolarDate()  
    28.     {  
    29.         m_IsLeapMonth = false;  
    30.         m_LunarYearSexagenary = null;  
    31.         m_LunarYearAnimal = null;  
    32.         m_LunarYearText = null;  
    33.         m_LunarMonthText = null;  
    34.         m_LunarDayText = null;  
    35.         m_SolarWeekText = null;  
    36.         m_SolarConstellation = null;  
    37.         m_SolarBirthStone = null;  
    38.         m_LunarYear = calendar.GetYear(m_SolarDate);  
    39.         m_LunarMonth = calendar.GetMonth(m_SolarDate);  
    40. int leapMonth = calendar.GetLeapMonth(m_LunarYear);  
    41. if (leapMonth == m_LunarMonth)  
    42.         {  
    43.             m_IsLeapMonth = true;  
    44.             m_LunarMonth -= 1;  
    45.         }  
    46. else if (leapMonth > 0 && leapMonth < m_LunarMonth)  
    47.         {  
    48.             m_LunarMonth -= 1;  
    49.         }  
    50.         m_LunarDay = calendar.GetDayOfMonth(m_SolarDate);  
    51.         CalcConstellation(m_SolarDate, out m_SolarConstellation, out m_SolarBirthStone);  
    52.     }  
    53.     #endregion
    54.     #region 日历属性
    55. /// <summary>
    56. /// 阳历日期
    57. /// </summary>
    58. public DateTime SolarDate  
    59.     {  
    60. get { return m_SolarDate; }  
    61. set
    62.         {  
    63. if (m_SolarDate.Equals(value))  
    64. return;  
    65.             m_SolarDate = value;  
    66.             LoadFromSolarDate();  
    67.         }  
    68.     }  
    69. /// <summary>
    70. /// 星期几
    71. /// </summary>
    72. public string SolarWeekText  
    73.     {  
    74. get
    75.         {  
    76. if (string.IsNullOrEmpty(m_SolarWeekText))  
    77.             {  
    78. int i = (int) m_SolarDate.DayOfWeek;  
    79.                 m_SolarWeekText = ChineseWeekName[i];  
    80.             }  
    81. return m_SolarWeekText;  
    82.         }  
    83.     }  
    84. /// <summary>
    85. /// 阳历星座
    86. /// </summary>
    87. public string SolarConstellation  
    88.     {  
    89. get { return m_SolarConstellation; }  
    90.     }  
    91. /// <summary>
    92. /// 阳历诞生石
    93. /// </summary>
    94. public string SolarBirthStone  
    95.     {  
    96. get { return m_SolarBirthStone; }  
    97.     }  
    98. /// <summary>
    99. /// 阴历年份
    100. /// </summary>
    101. public int LunarYear  
    102.     {  
    103. get { return m_LunarYear; }  
    104.     }  
    105. /// <summary>
    106. /// 阴历月份
    107. /// </summary>
    108. public int LunarMonth  
    109.     {  
    110. get { return m_LunarMonth; }  
    111.     }  
    112. /// <summary>
    113. /// 是否阴历闰月
    114. /// </summary>
    115. public bool IsLeapMonth  
    116.     {  
    117. get { return m_IsLeapMonth; }  
    118.     }  
    119. /// <summary>
    120. /// 阴历月中日期
    121. /// </summary>
    122. public int LunarDay  
    123.     {  
    124. get { return m_LunarDay; }  
    125.     }  
    126. /// <summary>
    127. /// 阴历年干支
    128. /// </summary>
    129. public string LunarYearSexagenary  
    130.     {  
    131. get
    132.         {  
    133. if (string.IsNullOrEmpty(m_LunarYearSexagenary))  
    134.             {  
    135. int y = calendar.GetSexagenaryYear(this.SolarDate);  
    136.                 m_LunarYearSexagenary = CelestialStem.Substring((y - 1) % 10, 1) + TerrestrialBranch.Substring((y - 1) % 12, 1);  
    137.             }  
    138. return m_LunarYearSexagenary;  
    139.         }  
    140.     }  
    141. /// <summary>
    142. /// 阴历年生肖
    143. /// </summary>
    144. public string LunarYearAnimal  
    145.     {  
    146. get
    147.         {  
    148. if (string.IsNullOrEmpty(m_LunarYearAnimal))  
    149.             {  
    150. int y = calendar.GetSexagenaryYear(this.SolarDate);  
    151.                 m_LunarYearAnimal = Animals.Substring((y - 1) % 12, 1);  
    152.             }  
    153. return m_LunarYearAnimal;  
    154.         }  
    155.     }  
    156. /// <summary>
    157. /// 阴历年文本
    158. /// </summary>
    159. public string LunarYearText  
    160.     {  
    161. get
    162.         {  
    163. if (string.IsNullOrEmpty(m_LunarYearText))  
    164.             {  
    165.                 m_LunarYearText = Animals.Substring(calendar.GetSexagenaryYear(new DateTime(m_LunarYear, 1, 1)) % 12 - 1, 1);  
    166.                 StringBuilder sb = new StringBuilder();  
    167. int year = this.LunarYear;  
    168. int d;  
    169. do
    170.                 {  
    171.                     d = year % 10;  
    172.                     sb.Insert(0, ChineseNumber[d]);  
    173.                     year = year / 10;  
    174.                 } while (year > 0);  
    175.                 m_LunarYearText = sb.ToString();  
    176.             }  
    177. return m_LunarYearText;  
    178.         }  
    179.     }  
    180. /// <summary>
    181. /// 阴历月文本
    182. /// </summary>
    183. public string LunarMonthText  
    184.     {  
    185. get
    186.         {  
    187. if (string.IsNullOrEmpty(m_LunarMonthText))  
    188.             {  
    189.                 m_LunarMonthText = (this.IsLeapMonth ? "闰" : "") + ChineseMonthName[this.LunarMonth - 1];  
    190.             }  
    191. return m_LunarMonthText;  
    192.         }  
    193.     }  
    194. /// <summary>
    195. /// 阴历月中日期文本
    196. /// </summary>
    197. public string LunarDayText  
    198.     {  
    199. get
    200.         {  
    201. if (string.IsNullOrEmpty(m_LunarDayText))  
    202.                 m_LunarDayText = ChineseDayName[this.LunarDay - 1];  
    203. return m_LunarDayText;  
    204.         }  
    205.     }  
    206.     #endregion
    207. /// <summary>
    208. /// 根据指定阳历日期计算星座&诞生石
    209. /// </summary>
    210. /// <param name="date">指定阳历日期</param>
    211. /// <param name="constellation">星座</param>
    212. /// <param name="birthstone">诞生石</param>
    213. public static void CalcConstellation(DateTime date, out string constellation, out string birthstone)  
    214.     {  
    215. int i = Convert.ToInt32(date.ToString("MMdd"));  
    216. int j;  
    217. if (i >= 321 && i <= 419)  
    218.             j = 0;  
    219. else if (i >= 420 && i <= 520)  
    220.             j = 1;  
    221. else if (i >= 521 && i <= 621)  
    222.             j = 2;  
    223. else if (i >= 622 && i <= 722)  
    224.             j = 3;  
    225. else if (i >= 723 && i <= 822)  
    226.             j = 4;  
    227. else if (i >= 823 && i <= 922)  
    228.             j = 5;  
    229. else if (i >= 923 && i <= 1023)  
    230.             j = 6;  
    231. else if (i >= 1024 && i <= 1121)  
    232.             j = 7;  
    233. else if (i >= 1122 && i <= 1221)  
    234.             j = 8;  
    235. else if (i >= 1222 || i <= 119)  
    236.             j = 9;  
    237. else if (i >= 120 && i <= 218)  
    238.             j = 10;  
    239. else if (i >= 219 && i <= 320)  
    240.             j = 11;  
    241. else
    242.         {  
    243.             constellation = "未知星座";  
    244.             birthstone = "未知诞生石";  
    245. return;  
    246.         }  
    247.         constellation = Constellations[j];  
    248.         birthstone = BirthStones[j];  
    249.         #region 星座划分
    250. //白羊座:   3月21日------4月19日     诞生石:   钻石   
    251. //金牛座:   4月20日------5月20日   诞生石:   蓝宝石   
    252. //双子座:   5月21日------6月21日     诞生石:   玛瑙   
    253. //巨蟹座:   6月22日------7月22日   诞生石:   珍珠   
    254. //狮子座:   7月23日------8月22日   诞生石:   红宝石   
    255. //处女座:   8月23日------9月22日   诞生石:   红条纹玛瑙   
    256. //天秤座:   9月23日------10月23日     诞生石:   蓝宝石   
    257. //天蝎座:   10月24日-----11月21日     诞生石:   猫眼石   
    258. //射手座:   11月22日-----12月21日   诞生石:   黄宝石   
    259. //摩羯座:   12月22日-----1月19日   诞生石:   土耳其玉   
    260. //水瓶座:   1月20日-----2月18日   诞生石:   紫水晶   
    261. //双鱼座:   2月19日------3月20日   诞生石:   月长石,血石  
    262.         #endregion
    263.     }  
    264.     #region 阴历转阳历
    265. /// <summary>
    266. /// 获取指定年份春节当日(正月初一)的阳历日期
    267. /// </summary>
    268. /// <param name="year">指定的年份</param>
    269. private static DateTime GetLunarNewYearDate(int year)  
    270.     {  
    271.         DateTime dt = new DateTime(year, 1, 1);  
    272. int cnYear = calendar.GetYear(dt);  
    273. int cnMonth = calendar.GetMonth(dt);  
    274. int num1 = 0;  
    275. int num2 = calendar.IsLeapYear(cnYear) ? 13 : 12;  
    276. while (num2 >= cnMonth)  
    277.         {  
    278.             num1 += calendar.GetDaysInMonth(cnYear, num2--);  
    279.         }  
    280.         num1 = num1 - calendar.GetDayOfMonth(dt) + 1;  
    281. return dt.AddDays(num1);  
    282.     }  
    283. /// <summary>
    284. /// 阴历转阳历
    285. /// </summary>
    286. /// <param name="year">阴历年</param>
    287. /// <param name="month">阴历月</param>
    288. /// <param name="day">阴历日</param>
    289. /// <param name="IsLeapMonth">是否闰月</param>
    290. public static DateTime GetDateFromLunarDate(int year, int month, int day, bool IsLeapMonth)  
    291.     {  
    292. if (year < 1902 || year > 2100)  
    293. throw new Exception("只支持1902~2100期间的农历年");  
    294. if (month < 1 || month > 12)  
    295. throw new Exception("表示月份的数字必须在1~12之间");  
    296. if (day < 1 || day > calendar.GetDaysInMonth(year, month))  
    297. throw new Exception("农历日期输入有误");  
    298. int num1 = 0, num2 = 0;  
    299. int leapMonth = calendar.GetLeapMonth(year);  
    300. if (((leapMonth == month + 1) && IsLeapMonth) || (leapMonth > 0 && leapMonth <= month))  
    301.             num2 = month;  
    302. else
    303.             num2 = month - 1;  
    304. while (num2 > 0)  
    305.         {  
    306.             num1 += calendar.GetDaysInMonth(year, num2--);  
    307.         }  
    308.         DateTime dt = GetLunarNewYearDate(year);  
    309. return dt.AddDays(num1 + day - 1);  
    310.     }  
    311. /// <summary>
    312. /// 阴历转阳历
    313. /// </summary>
    314. /// <param name="date">阴历日期</param>
    315. /// <param name="IsLeapMonth">是否闰月</param>
    316. public static DateTime GetDateFromLunarDate(DateTime date, bool IsLeapMonth)  
    317.     {  
    318. return GetDateFromLunarDate(date.Year, date.Month, date.Day, IsLeapMonth);  
    319.     }  
    320.     #endregion
    321.     #region 从阴历创建日历
    322. /// <summary>
    323. /// 从阴历创建日历实体
    324. /// </summary>
    325. /// <param name="year">阴历年</param>
    326. /// <param name="month">阴历月</param>
    327. /// <param name="day">阴历日</param>
    328. /// <param name="IsLeapMonth">是否闰月</param>
    329. public static ChineseCalendarInfo FromLunarDate(int year, int month, int day, bool IsLeapMonth)  
    330.     {  
    331.         DateTime dt = GetDateFromLunarDate(year, month, day, IsLeapMonth);  
    332. return new ChineseCalendarInfo(dt);  
    333.     }  
    334. /// <summary>
    335. /// 从阴历创建日历实体
    336. /// </summary>
    337. /// <param name="date">阴历日期</param>
    338. /// <param name="IsLeapMonth">是否闰月</param>
    339. public static ChineseCalendarInfo FromLunarDate(DateTime date, bool IsLeapMonth)  
    340.     {  
    341. return FromLunarDate(date.Year, date.Month, date.Day, IsLeapMonth);  
    342.     }  
    343. /// <summary>
    344. /// 从阴历创建日历实体
    345. /// </summary>
    346. /// <param name="date">表示阴历日期的8位数字,例如:20070209</param>
    347. /// <param name="IsLeapMonth">是否闰月</param>
    348. public static ChineseCalendarInfo FromLunarDate(string date, bool IsLeapMonth)  
    349.     {  
    350.         Regex rg = new System.Text.RegularExpressions.Regex(@"^\d{7}(\d)$");  
    351.         Match mc = rg.Match(date);  
    352. if (!mc.Success)  
    353.         {  
    354. throw new Exception("日期字符串输入有误!");  
    355.         }  
    356.         DateTime dt = DateTime.Parse(string.Format("{0}-{1}-{2}", date.Substring(0, 4), date.Substring(4, 2), date.Substring(6, 2)));  
    357. return FromLunarDate(dt, IsLeapMonth);  
    358.     }  
    359.     #endregion
    360. private static ChineseLunisolarCalendar calendar = new ChineseLunisolarCalendar();  
    361. public const string ChineseNumber = "〇一二三四五六七八九";  
    362. public const string CelestialStem = "甲乙丙丁戊己庚辛壬癸";  
    363. public const string TerrestrialBranch = "子丑寅卯辰巳午未申酉戌亥";  
    364. public const string Animals = "鼠牛虎兔龙蛇马羊猴鸡狗猪";  
    365. public static readonly string[] ChineseWeekName   
    366.         = new string[] { "星期天", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六" };  
    367. public static readonly string[] ChineseDayName = new string[] {  
    368. "初一","初二","初三","初四","初五","初六","初七","初八","初九","初十",  
    369. "十一","十二","十三","十四","十五","十六","十七","十八","十九","二十",  
    370. "廿一","廿二","廿三","廿四","廿五","廿六","廿七","廿八","廿九","三十"};  
    371. public static readonly string[] ChineseMonthName  
    372.         = new string[] { "正", "二", "三", "四", "五", "六", "七", "八", "九", "十", "十一", "十二" };  
    373. public static readonly string[] Constellations   
    374.         = new string[] { "白羊座", "金牛座", "双子座", "巨蟹座", "狮子座", "处女座", "天秤座", "天蝎座", "射手座", "摩羯座", "水瓶座", "双鱼座" };  
    375. public static readonly string[] BirthStones   
    376.         = new string[] { "钻石", "蓝宝石", "玛瑙", "珍珠", "红宝石", "红条纹玛瑙", "蓝宝石", "猫眼石", "黄宝石", "土耳其玉", "紫水晶", "月长石,血石" };  
  • 相关阅读:
    转:深入 AngularUI Router
    angularJS $scope的$apply方法实现model刷新
    CSS 如何让 height:100%; 起作用
    【AngularJs】---$sce 输出Html
    angular 组件之间传值
    kendo Grid 列添加自定义模板
    关于“内控点”
    关于总结
    咏春
    一只老鼠夹
  • 原文地址:https://www.cnblogs.com/cwfsoft/p/1725141.html
Copyright © 2011-2022 走看看