|
====================================
http://hi.baidu.com/deng%5Flianjie/blog/item/98ab3b133c4d3928dd54015b.html
function rili($style,$Atime){
$debug = false;
$glmonth = date("n",$Atime); //1-12
$glday = date("j",$Atime); //1-31
$glweek = date("w",$Atime); //0-6
$glyear = date("Y",$Atime); //
if( $glweek==0 || $glweek==6 ){
$bgcolor="#ff5555";
$fontcolor="yellow";
}else{
$bgcolor="#66ccff";
$fontcolor="black";
}
$chday=explode(" ","星期日 星期一 星期二 星期三 星期四 星期五 星期六");
$chnum=explode(" ","一 二 三 四 五 六 七 八 九 十");
//$isBig=explode(" ","大 小");
$dayName = explode(" ","初一 初二 初三 初四 初五 初六 初七 初八 初九 初十 十一 十二 十三 十四 十五 十六 十七 十八 十九 二十 廿一 廿二 廿三 廿四 廿五 廿六 廿七 廿八 廿九 三十");
$date = mktime(0,0,0,2,5,2000); //从庚辰年春节算起
$K = floor(($Atime - date("U",$date) )/86400 );
//
//$daypyear = array(354,384,354,355,384,355);
$skydry = explode(" ","甲 乙 丙 丁 戊 已 庚 辛 壬 癸");
$groundbranch = explode(" ","子 丑 寅 卯 辰 巳 午 未 申 酉 戌 亥");
$nongmonth = explode(" ","正月 二月 三月 四月 五月 六月 七月 八月 九月 十月 十一月 腊月");
for($i=0;$i < 60;$i++)
{
$yearName[] = $skydry[($i + 6 )%10].$groundbranch[($i + 4)%12]."年";
}
//$yearName = explode(" ","庚辰年 辛巳年 壬午年 癸未年 甲申年 乙酉年 丙戌年 丁亥年");
$adaypmonth = array(
explode(" ","30 30 29 29 30 29 29 30 29 30 30 29" ), //庚辰年 00
explode(" ","30 30 29 30 -29 30 29 29 30 29 30 29 30" ), //辛巳年 01
explode(" ","30 30 29 30 29 30 29 29 30 29 30 29" ), //壬午年 02
explode(" ","30 30 29 30 30 29 30 29 29 30 29 30" ), //癸未年 03
explode(" ","29 30 -29 30 30 29 30 29 30 29 30 29 30" ), //甲申年 04
explode(" ","29 30 29 30 29 30 30 29 30 29 30 29" ), //乙酉年 05
explode(" ","30 29 30 29 30 29 30 29 -30 30 29 30 30" ), //丙戌年 06
explode(" ","29 29 30 29 29 30 29 30 30 30 29 30" ), //丁亥年 07
explode(" ","30 29 29 30 29 29 30 29 30 30 29 30" ) //戊子年 08
);
if($debug)print_r($adaypmonth);
while(list($i,$j) = each($adaypmonth))
{
//$daypyear[$i] = array_sum($j);
$p=0;
while(list($m,$n) = each($j))
{
if($n>0)
{
$amname[$i][$m] = $nongmonth[$p];
$p++;
$daypyear[$i] += $n;
}else
{
$amname[$i][$m] = "闰".$nongmonth[$p];
$daypyear[$i] -= $n;
}
if($n == 29 || $n == -29)
{
$amname[$i][$m] = $amname[$i][$m]."小";
}else
{
$amname[$i][$m] = $amname[$i][$m]."大";
}
}
}
/*
$amname = array(
"正月 二月 三月 四月 五月 六月 七月 八月 九月 十月 十一月 腊月", //00
"正月 二月 三月 四月 闰四月 五月 六月 七月 八月 九月 十月 十一月 腊月", //01
"正月 二月 三月 四月 五月 六月 七月 八月 九月 十月 十一月 腊月", //02
"正月 二月 三月 四月 五月 六月 七月 八月 九月 十月 十一月 腊月", //03
"正月 二月 闰二月 三月 四月 五月 六月 七月 八月 九月 十月 十一月 腊月", //04
"正月 二月 三月 四月 五月 六月 七月 八月 九月 十月 十一月 腊月", //05
"正月 二月 三月 四月 五月 六月 七月 八月 闰八月 九月 十月 十一月 腊月", //06
"正月 二月 三月 四月 五月 六月 七月 八月 九月 十月 十一月 腊月", //07
"正月 二月 三月 四月 五月 六月 七月 八月 九月 十月 十一月 腊月", //08
);
*/
//
$yearnum = 0;
while($K >= $daypyear[$yearnum]){
// echo "K=$K yearnum=$yearnum daypyear=${daypyear[$yearnum]}\n";
$K-=$daypyear[$yearnum++];
}
if($debug)echo "K:".$K;
$year = $yearName[$yearnum];
$month = $adaypmonth[$yearnum];
//$mName = explode(" ",$amname[$yearnum]);
$mName = $amname[$yearnum];
$i=0;
while($K >= $month[$i])$K -= abs($month[$i++]);
/*
if($month[$i]==29)$l=$isBig[1];
else $l=$isBig[0]; //大小月
*/
// year 农历的年份
// i,nlmonth 农历的月数 数组序号0-12(11)
// K,nlday 农历的天数 0-29(28)
$nlmonth = $i;
$nlday = $K+1;
$JR1 = "";
//公历节日
//固定节日
$gljr = array(
101=>"元旦",
202=>"世界湿地日(1996)",
214=>"情人节",
303=>"全国爱耳日",
308=>"妇女节(1910)",
312=>"植树节(1979)",
315=>"国际消费者权益日",
320=>"世界睡眠日",
325=>"世界气象日",
401=>"愚人节",
407=>"世界卫生日",
501=>"国际劳动节",
504=>"中国青年节",
508=>"世界红十字日",
512=>"国际护士节",
519=>"全国助残日",
601=>"国际儿童节",
605=>"世界环境日",
622=>"中国儿童慈善活动日",
623=>"国际奥林匹克日",
701=>"中国gcd成立(1921)",
707=>"中国人民抗日战争纪念日",
801=>"中国人民解放军建军(1927)",
903=>"抗日战争胜利纪念日(1945)",
908=>"国际扫盲日",
910=>"教师节",
916=>"世界臭氧层保护日",
918=>"九?一八纪念日",
927=>"世界旅游日",
929=>"国际聋人节",
1001=>"中华人民共和国成立",
1014=>"世界标准日",
1024=>"联合国日",
1205=>"国际志愿人员日",
1229=>"12.9运动纪念日",
1225=>"圣诞节"
);
if(isset($gljr[$glmonth*100+$glday])) $JR1.=$gljr[$glmonth*100+$glday];
//不固定节日
//及
$JR="";
switch($glmonth){
case 1:
switch($glday){
case 1:
$bgcolor="#ff5555"; //元旦
$fontcolor="yellow";
break;
}
break;
case 5:
switch($glday){
case 1:
$bgcolor="#ff5555"; //五一
$fontcolor="yellow";
break;
}
if(($glday>7)&&($glday<15)&&($glweek==0))$JR.="母亲节";
break;
case 6:
if(($glday>14)&&($glday<22)&&($glweek==0))$JR.="父亲节";
break;
case 9:
switch($glday){
case 18:
$bgcolor="#666666"; //9.18
$fontcolor="#ffffff";
break;
}
break;
case 10:
switch(date("j",$Atime)){
case 1:
$bgcolor="#ff5555"; //国庆
$fontcolor="yellow";
$JR.=(date("Y",$Atime)-1949)."周年";break;
}
break;
}
if(strlen($JR)>1)$JR2=$JR;
$JR="";
$JR3="";
//固定农历节日
//*********农历节日
//K为日减一
switch(substr($mName[$i],0,-2)){
case "正月":
switch($nlday){
case 1:
$bgcolor="#ff5555"; //
$fontcolor="yellow";
$JR3.="春节";break;
case 15:
$JR3.="元宵节";break;
}
break;
case "二月":
switch($nlday){
case 2:
$JR3.="龙抬头";break;
}
break;
case "三月":
break;
case "四月":
break;
case "五月":
switch($nlday){
case 5:
$JR3.="端午节";break;
}
break;
case "六月":
break;
case "七月":
switch($nlday){
case 7:
$JR3.="七夕";break;
}
break;
case "八月":
switch($nlday){
case 15:
$bgcolor="#ff5555"; //
$fontcolor="yellow";
$JR3.="中秋节";break;
}
break;
case "九月":
switch($nlday){
case 9:
$JR3.="重阳节";break;
}
break;
case "十月":
break;
case "十一月":
break;
case "腊月":
switch($nlday){
case 8:
$JR3.="腊八";break;
case 25:
$JR3.="小年";break;
}
if(($nlday==30)||(($nlday==29)&&(substr($mName[$i],-2)==="小"))){
$bgcolor="#ff5555"; //
$fontcolor="yellow";
$JR3.="除夕";
}
break;
}
//24节气
$nl24j[2002] = array(
105=>"小寒",
120=>"大寒",
204=>"立春",
219=>"雨水",
306=>"惊蛰",
321=>"春分",
405=>"清明",
420=>"谷雨",
506=>"立夏",
521=>"小满",
606=>"芒种",
621=>"夏至",
707=>"小暑",
723=>"大暑",
808=>"立秋",
823=>"处暑",
908=>"白露",
923=>"秋分",
1008=>"寒露",
1023=>"霜降",
1107=>"立冬",
1122=>"小雪",
1207=>"大雪",
1222=>"冬至"
);
$nl24j[2003] = array(
106=>"小寒",
120=>"大寒",
204=>"立春",
219=>"雨水",
306=>"惊蛰",
321=>"春分",
405=>"清明",
420=>"谷雨",
506=>"立夏",
521=>"小满",
606=>"芒种",
622=>"夏至",
707=>"小暑",
723=>"大暑",
808=>"立秋",
823=>"处暑",
908=>"白露",
923=>"秋分",
1009=>"寒露",
1024=>"霜降",
1108=>"立冬",
1123=>"小雪",
1207=>"大雪",
1222=>"冬至"
);
$nl24j[2004] = array(
106=>"小寒",
121=>"大寒",
204=>"立春",
219=>"雨水",
305=>"惊蛰",
320=>"春分",
402=>"清明",
420=>"谷雨",
505=>"立夏",
521=>"小满",
605=>"芒种",
621=>"夏至",
707=>"小暑",
722=>"大暑",
807=>"立秋",
823=>"处暑",
907=>"白露",
923=>"秋分",
1008=>"寒露",
1023=>"霜降",
1107=>"立冬",
1122=>"小雪",
1207=>"大雪",
1221=>"冬至"
);
if(isset($gl24j[$glyear][$glmonth*100+$glday])) $JR4.=$gl24j[$glyear][$glmonth*100+$glday];
if($style=="1"){
$str = "" .date("Y年n月j日",$Atime).$chday[date("w",$Atime)]."
";
$str .="农历" .$year."".$mName[$i]."".$dayName[$K]."";
if(strlen("$JR1 $JR2 $JR3 $JR4")>3)$str .="
$JR1 $JR2 $JR3 $JR4";
}else{
$str = "".date("Y年",$Atime)."
".date("n月j日",$Atime)."
".$chday[date("w",$Atime)]."
";
$str .="农历".$year."
".$mName[$i]."".$dayName[$K];
if(strlen($JR1)>1)$str.="
$JR1";
if(strlen($JR2)>1)$str.="
$JR2";
if(strlen($JR3)>1)$str.="
$JR3";
if(strlen($JR4)>1)$str.="
$JR4";
}
//***************************/
echo ";
echo ' bgcolor="';
echo $bgcolor.'"';
echo ">$str $JR";
echo "
";
} //end function rili
?>
函数描述及例子
=========================
rili("1",time()-3600*24);
?>
显示结果:
2009年
1月3日
星期六
农历戊子年
腊月大初八
腊八