首頁  >  文章  >  後端開發  >  PHP陰曆轉農曆的實現代碼

PHP陰曆轉農曆的實現代碼

WBOY
WBOY原創
2016-07-25 08:56:07884瀏覽
複製程式碼
  1. /**
  2. **PHP陰曆轉農曆
  3. * by bbs.it-home.org
  4. */
  5. class Lunar {
  6. var $MIN_YEAR = 1891;
  7. var $ = 2100;
  8. var $lunarInfo = array(
  9. 數組(0,2,9,21936),數組(6,1,30,9656),數組(0,2,17,9584),數組( 0,2,6,21168),數組(5,1,26,43344),數組(0,2,13,59728),
  10. 數組(0,2,2,27296),數組(3, 1 ,22,44368),數組(0,2,10,43856),數組(8,1,30,19304),數組(0,2,19,19168),數組(0,2,8,42352) ,
  11. 陣列(5,1,29,21096),陣列(0,2,16,53856),陣列(0,2,4,55632),陣列(4,1,25,27304),陣列( 0 ,2,13,22176),陣列(0,2,2,39632),
  12. 陣列(2,1,22,19176),陣列(0,2,10,19168),陣列(6,1 , 30,42200),數組(0,2,18,42192),數組(0,2,6,53840),數組(5,1,26,54568),
  13. 數組(0,2,14, 46400 ),陣列(0,2,3,54944),陣列(2,1,23,38608),陣列(0,2,11,38320),陣列(7,2,1,18872),陣列(0 , 2,20,18800),
  14. 陣列(0,2,8,42160),陣列(5,1,28,45656),陣列(0,2,16,27216),陣列(0,2, 5 ,27968),數組(4,1,24,44456),數組(0,2,13,11104),
  15. 數組(0,2,2,38256),數組(2,1,23,18808 ) ,數組(0,2,10,18800),數組(6,1,30,25776),數組(0,2,17,54432),數組(0,2,6,59984),
  16. 數組( 5,1,26,27976),數組(0,2,14,23248),數組(0,2,4,11104),數組(3,1,24,37744),數組(0,2,11 , 37600),數組(7,1,31,51560),
  17. 數組(0,2,19,51536),數組(0,2,8,54432),數組(6,1,27,55888) ,數組(0,2,15,46416),數組(0,2,5,22176),數組(4,1,25,43736),
  18. 數組(0,2,13,9680),數組( 0 ,2,2,37584),數組(2,1,22,51544),數組(0,2,10,43344),數組(7,1,29,46248),數組(0,2,17, 27808 ),
  19. 數組(0,2,6,46416),數組(5,1,27,21928),數組(0,2,14,19872),數組(0,2,3,42416),數組(3,1,24,21176),陣列(0,2,12,21168),
  20. 陣列(8,1,31,43344),陣列(0,2,18,59728),陣列(0 , 2,8,27296),數組(6,1,28,44368),數組(0,2,15,43856),數組(0,2,5,19296),
  21. 數組(4,1, 25 ,42352),數組(0,2,13,42352),數組(0,2,2,21088),數組(3,1,21,59696),數組(0,2,9,55632),數組( 7,1,30,23208),
  22. 陣列(0,2,17,22176),陣列(0,2,6,38608),陣列(5,1,27,19176),陣列(0, 2 ,15,19152),陣列(0,2,3,42192),陣列(4,1,23,53864),
  23. 陣列(0,2,11,53840),陣列(8,1,31 , 54568),數組(0,2,18,46400),數組(0,2,7,46752),數組(6,1,28,38608),數組(0,2,16,38320),
  24. 數組(0,2,5,18864),數組(4,1,25,42168),數組(0,2,13,42160),數組(10,2,2,45656),數組(0,2 , 20,27216),數組(0,2,9,27968),
  25. 數組(6,1,29,44448),數組(0,2,17,43872),數組(0,2,6, 38256 ),數組(5,1,27,18808),數組(0,2,15,18800),數組(0,2,4,25776),
  26. 數組(3,1,23,27216),數組(0,2,10,59984),數組(8,1,31,27432),數組(0,2,19,23232),數組(0,2,7,43872),數組(5,1, 28 ,37736),
  27. 數組(0,2,16,37600),數組(0,2,5,51552),數組(4,1,24,54440),數組(0,2,12,54432 ) ,數組(0,2,1,55888),數組(2,1,22,23208),
  28. 數組(0,2,9,22176),數組(7,1,29,43736),數組( 0,2,18,9680),陣列(0,2,7,37584),陣列(5,1,26,51544),陣列(0,2,14,43344),
  29. 陣列(0, 2 ,3,46240),數組(4,1,23,46416),數組(0,2,10,44368),數組(9,1,31,21928),數組(0,2,19,19360) ,數組(0,2,8,42416),
  30. 數組(6,1,28,21176),數組(0,2,16,21168),數組(0,2,5,43312),數組( 4 ,1,25,29864),數組(0,2,12,27296),數組(0,2,1,44368),
  31. 數組(2,1,22,19880),數組(0,2 , 10,19296),數組(6,1,29,42352),數組(0,2,17,42208),數組(0,2,6,53856),數組(5,1,26,59696),
  32. 數組(0,2,13,54576),數組(0,2,3,23200),數組(3,1,23,27472),數組(0,2,11,38608),數組(11 , 1,31,19176),數組(0,2,19,19152),
  33. 數組(0,2,8,42192),數組(6,1,28,53848),數組(0,2, 15 ,53840),數組(0,2,4,54560),數組(5,1,24,55968),數組(0,2,12,46496),
  34. 數組(0,2,1,22224 ) ,數組(2,1,22,19160),數組(0,2,10,18864),數組(7,1,30,42168),數組(0,2,17,42160),數組(0, 2 ,6,43600),
  35. 陣列(5,1,26,46376),陣列(0,2,14,27936),陣列(0,2,2,44448),陣列(3,1,23 , 21936),數組(0,2,11,37744),數組(8,2,1,18808),
  36. 數組(0,2,19,18800),數組(0,2,8,25776) ,數組(6,1,28,27216),數組(0,2,15,59984),數組(0,2,4,27424),數組(4,1,24,43872),
  37. 數組( 0 ,2,12,43744),數組(0,2,2,37600),數組(3,1,21,51568),數組(0,2,9,51552),數組(7,1,29, 54440 ),數組(0,2,17,54432),
  38. 數組(0,2,5,55888),數組(5,1,26,23208),數組(0,2,14,22176),數組(0,2,3,42704),數組(4,1,23,21224),數組(0,2,11,21200),
  39. 數組(8,1,31,43352),數組(0 , 2,19,43344),數組(0,2,7,46240),數組(6,1,27,46416),數組(0,2,15,44368),數組(0,2,5,21920 ) ,
  40. 數組(4,1,24,42448),數組(0,2,12,42416),數組(0,2,2,21168),數組(3,1,22,43320),數組( 0,2,9,26928),數組(7,1,29,29336),
  41. 數組(0,2,17,27296),數組(0,2,6,44368),數組(5, 1 ,26,19880),數組(0,2,14,19296),數組(0,2,3,42352),數組(4,1,24,21104),
  42. 數組(0,2,10 , 53856),數組(8,1,30,59696),數組(0,2,18,54560),數組(0,2,7,55968),數組(6,1,27,27472),數組( 0 ,2,15,22224),
  43. 陣列(0,2,5,19168),陣列(4,1,25,42216),陣列(0,2,12,42192),陣列(0,2 , 1,53584),數組(2,1,21,55592),數組(0,2,9,54560)
  44. );
  45. /**
  46. * 將陽曆轉換為陰曆
  47. * @param year 公曆-年
  48. * @param month 公曆-月
  49. * @param date 公曆-日
  50. */
  51. 函數convertSolarTonar($年/***/
  52. 函數convertSolarTonar($年/***/
  53. 函數convertSolarTonar($年/***/
  54. 函數convertSolarTonar($年,$月,$日期){
  55. //調試器;$yearData = $this->lunarInfo[$year-$this->MIN_YEAR];if($year==$這- >MIN_YEAR&&$月return array(1891,'正月','初一','辛卯',1,1,'兔子');
  56. }
  57. return $this->getLunarByBetween($year,$this-> ; getDaysBetweenSolar($year,$month,$date,$yearData[1],$yearData[2]));
  58. }
  59. 函數convertSolarMonthToLunar($year,$month) {
  60. $yearSolarMonthToLunar($year,$month) {
  61. $yearData = $ thisyearData = $ ->lunarInfo[$year-$this->MIN_YEAR];
  62. if($year==$this->MIN_YEAR&&$month返回資料庫( 1891,'正月','初一','辛卯',1,1,'兔');
  63. }
  64. $month_days_ary = array(31, 28, 31, 30, 31, 30, 31 , 31, 30 , 31, 30, 31);
  65. $dd = $month_days_ary[$month];
  66. if($this->isLeapYear($year) && $month == 2) $dd++;
  67. $lunar_ary = array();
  68. for ($i = 1; $i $array = $this->getLunarByBetween($year,$this->getDaysBetweenSolar ($year, $month, $i, $yearData[1], $yearData[2]));
  69. $array[] = $year。 🎜>$lunar_ary[$i] = $array;
  70. }
  71. return $lunar_ary;
  72. }
  73. /**
  74. * 將陰曆轉換為陽曆
  75. * @param year 陰曆-年
  76. * @param month 陰曆-月,閏月處理:例如如果當年閏五月,那麼第二個五月就傳六月,相當於陰曆有13個月,只是有的時候第13個月的天數為0
  77. * @param date 陰曆-日
  78. */
  79. function convertLunarToar($year ,$month,$year $date){
  80. $yearData = $this->lunarInfo[$year-$this->MIN_YEAR];
  81. $ Between = $this->getDaysBetweenLunar($year,$month ,$date);
  82. $res = mktime(0,0,0,$yearData[1],$yearData[2],$year);
  83. $res = date('Y-m-d', $ res+$ 之間*24* 60 *60);
  84. $day =explode('-', $res);
  85. $year = $day[0];
  86. $month= $day[1] ;
  87. $day = $day[2];
  88. 返回備份($year, $month, $day);
  89. }
  90. /**
  91. * 判斷是否為閏年
  92. * @param year
  93. */
  94. function isLeapYear( $year){
  95. return (($year%4==0 && $year%100 !=0) || ($year%400==0));
  96. }
  97. /**
  98. * 取得幹支紀年
  99. * @param year
  100. */
  101. function getLunarYearName($year){
  102. $sky = array('庚','辛','壬','癸','甲','乙','丙','丁','戊' ,'己');
  103. $earth = array('申','酉','戌','亥','子','醜','寅','卯','辰' , '巳','午','未');
  104. $year = $year.'';
  105. return $sky[$year{3}].$earth[$year%12];
  106. }
  107. /**
  108. * 依陰曆年取得生肖
  109. * @param year 陰曆年
  110. */
  111. function getYearZodiac($year){
  112. $zodiac = array('猴','雞','狗','豬','鼠' ,'牛','虎','兔','龍','蛇','馬','羊');
  113. return $zodiac[$year%12];
  114. }
  115. /**
  116. * 取得陽曆月份的天數
  117. * @param year 陽曆-年
  118. * @param month 陽曆-月
  119. */
  120. function getSolarMonthDays($year,$month){
  121. $monthHash = array('1'=>31,'2'=>; $ this->isLeapYear($year)?29:28,'3'=>31,'4'=>30,'5'=>31,'6'=>30,'7'=>31,'8 '=>31,'9'=>30,'10'=>31,'11'=>30,'12'=>31);
  122. 回傳$monthHash["$month"];
  123. }
  124. /**
  125. * 取得陰曆月份的天數
  126. * @param year 陰曆-年
  127. * @param month 陰曆-月,從一月開始
  128. */
  129. 函數getLunarMonthDays($year,$month){
  130. $monthData = $this->getLunarMonths( $year);
  131. return $monthData[$month -1];
  132. }
  133. /**
  134. * 取得陰曆每月的天數的陣列
  135. * @param year
  136. */
  137. function getLunarMonths($year){
  138. $yearData = $this ->lunarInfo[$year - $this->MIN_YEAR] ;
  139. $leapMonth = $yearData[0];
  140. $bit = decbin($yearData[3]);
  141. for ($i = 0; $i $bitArray[$i] = substr($bit, $i, 1);
  142. }
  143. for($k=0,$klen= 16-count($bitArray);$ karray_unshift($bitArray, '0');
  144. }
  145. $bitArray = array_slice($bitArray,0,($LeapMonth==0?12:13) );
  146. for($i=0; $i$bitArray[$i] = $bitArray[$i] + 29;
  147. }
  148. return $bitArray;
  149. }
  150. /**
  151. * 取得農曆每年的天數
  152. * @param year 農曆年份
  153. */
  154. function getLunarYearDays($year){
  155. $yearData = $this->; LunarInfo[$year-$this->MIN_YEAR];
  156. $monthArray = $this->getLunarYearMonths($year);
  157. $len = count($monthArray);
  158. return ($monthArray[ $len -1]==0?$monthArray[$len-2]:$monthArray[$len-1]);
  159. }
  160. function getLunarYearMonths($year){
  161. //調試器;
  162. $monthData = $this->getLunarMonths($year);
  163. $res=array();
  164. $temp=0;
  165. $yearData = $this->lunarInfo[$year- $this- >MIN_YEAR];
  166. $len = ($yearData[0]==0?12:13);
  167. for($i=0;$i$temp =0;
  168. for($j=0;$j$temp+=$monthData[$j];
  169. }
  170. array_push( $res, $ temp);
  171. }
  172. return $res;
  173. }
  174. /**
  175. * 取得閏月
  176. * @param year 陰曆年份
  177. */
  178. function getLeapMonth($year){
  179. $yearData = $ this->lunarInfo [$year-$this->MIN_YEAR];
  180. return $yearData[0];
  181. }
  182. /**
  183. * 計算陰曆日期與正月初一相隔的天數
  184. * @param year
  185. * @param month
  186. * @param date
  187. */
  188. function getDaysBetweenLunar($year ,$月,$日期){
  189. $yearMonth = $this->getLunarMonths($year);
  190. $res=0;
  191. for($i=1;$i$ res +=$yearMonth[$i-1];
  192. }
  193. $res+=$date-1;
  194. return $res;
  195. }
  196. /**
  197. * 計算2個陽曆日期之間的天數
  198. * @param year 陽曆年
  199. * @param cmonth
  200. * @param cdate
  201. * @param dmonth 陰曆正月對應的陽曆月份
  202. * @param ddate 陰曆初一對應的陽曆天數
  203. */
  204. function getDaysBetweenSolar($year,$cmonth,$cdate,$dmonth ,$ddate){
  205. $a = mktime(0,0,0,$cmonth,$cdate,$year);
  206. $b = mktime(0,0,0,$dmonth,$ddate,$年);
  207. return ceil(($a-$b)/24/3600);
  208. }
  209. /**
  210. * 根據距離正月初一的天數計算陰曆日期,例如今天是農曆幾月幾日星期幾等
  211. * @param year 陽曆年
  212. * @param between 天數
  213. */
  214. function getLunarByBetween($year,$Between){
  215. //調試器;
  216. $lunarArray = array();
  217. $yearMonth=array();
  218. $t=0;
  219. $e=0;
  220. $leapMonth= 0 ;
  221. $m='';
  222. if($ Between==0){
  223. array_push($lunarArray, $year,'正月','初一');
  224. $t = 1 ;
  225. $e = 1;
  226. }else{
  227. $year = $ 之間>0? $year : ($year-1);
  228. $yearMonth = $this->getLunarYearMonths($year);
  229. $leapMonth = $this->getLeapMonth($year);
  230. $ Between = $this->getLeapMonth($year);
  231. $ Between = $ Between >0?$ 之間: ($this->getLunarYearDays($year)+$ Between);
  232. for($i=0;$iif($ Between == $年月[$i]){
  233. $t=$i+2;
  234. $e=1;
  235. break;
  236. }else if($ Between$t=$i+1;
  237. $e=$ Between-(empty($yearMonth[$i-1])?0:$yearMonth[$i-1])+1;
  238. break ;
  239. }
  240. }
  241. $m = ($leapMonth!=0&&$t==$leapMonth+1)?('閏'.$this-> getCapitalNum($t- 1) , true) ):$this->getCapitalNum(($leapMonth!=0&&$leapMonth+1array_push($lunarArray,$year ,$ m, $this->getCapitalNum($e,false));
  242. }
  243. array_push($lunarArray,$this->getLunarYearName($year));//天干地支
  244. array_push ($lunarArray, $t ,$e);
  245. array_push($lunarArray,$this->getYearZodiac($year));// 12生肖
  246. array_push($lunarArray,$leapMonth);///H return $ LunarArray;
  247. }
  248. /**
  249. * 取得數字的陰曆叫法
  250. * @param num 數字
  251. * @param isMonth 是否是月份的數字
  252. */
  253. function getCapitalNum($num,$isMonth){
  254. $isMonth = $isMonth || false;
  255. $dateHash=array('0'=>'','1'=>'一','2'=>'二','3'=>'三','4'=> '四','5'=>'五','6'=>'六','7'=>'七','8'=>'八','9'=>'九',' 10'=>'十');
  256. $monthHash=array('0'=>'','1'=>'正月','2'=>'二月','3'=>'三月','4'=>'四月','5'=>'五月','6'=>'六月','7'=>'七月','8'=> '八月','9'=>'九月','10'=>'十月','11'=>'冬月','12'=>'臘月');
  257. $res = '';
  258. if($isMonth){
  259. $res = $monthHash[$num];
  260. }else{
  261. if($num$res = '初'.$dateHash[$num];
  262. }else if($num>10&&$num$res = '十'.$dateHash[$num-10];
  263. }else if($num==20){
  264. $res = "二十";
  265. } else if($num>20&&$num$res = "二十".$dateHash[$num-20];
  266. }else if($num==30){
  267. $ res = "三十";
  268. }
  269. }
  270. return $res;
  271. }
  272. }
  273. $lunar = new Lunar();
  274. $month = $lunar - >convertLunarToSolar(2012, 1,1);
  275. print_r($month);
  276. 退出;
複製程式碼
複製程式碼


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn