亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Delphi > 正文

中國農歷算法(delphi)

2019-11-18 18:14:19
字體:
來源:轉載
供稿:網友
 

// 節日算法 請參見 《農歷與西歷對照、萬年歷》
unit CNYear;

interface

uses sysutils;

type TCNDate = Cardinal;

function DecodeGregToCNDate(dtGreg:TDateTime):TCNDate;
function GetGregDateFromCN(cnYear,cnMonth,cnDay:Word;bLeap:Boolean=False):TDateTime;
function GregDateToCNStr(dtGreg:TDateTime):String;
function isCNLeap(cnDate:TCNDate):boolean;

implementation

const cstDateOrg:Integer=32900; //公歷1990-01-27的TDateTime表示 對應農歷1990-01-01
const cstCNYearOrg=1990;
const cstCNTable:array[cstCNYearOrg..cstCNYearOrg + 60] of WORD=(       //   unsigned 16-bit
24402, 3730, 3366, 13614, 2647, 35542, 858, 1749,           //1997
23401, 1865, 1683, 19099, 1323, 2651, 10926, 1386,           //2005
32213, 2980, 2889, 23891, 2709, 1325, 17757, 2741,           //2013
39850, 1490, 3493, 61098, 3402, 3221, 19102, 1366,           //2021
2773, 10970, 1746, 26469, 1829, 1611, 22103, 3243,           //2029
1370, 13678, 2902, 48978, 2898, 2853, 60715, 2635,           //2037
1195, 21179, 1453, 2922, 11690, 3474, 32421, 3365,           //2045
2645, 55901, 1206, 1461, 14038);                             //2050
//建表方法:
// 0101 111101010010     高四位是閏月位置,后12位表示大小月,大月30天,小月29天,
//閏月一般算小月,但是有三個特例2017/06,2036/06,2047/05
//對于特例則高四位的閏月位置表示法中的最高為設置為1 特殊處理用wLeapNormal變量
// //2017/06 28330->61098 2036/06 27947->60715 2047/05 23133->55901

//如果希望用匯編,這里有一條信息:農歷不會滯后公歷2個月.
//將公歷轉換為農歷
//返回:12位年份+4位月份+5位日期
function DecodeGregToCNDate(dtGreg:TDateTime):TCNDate;
var
  iDayLeave:Integer;
  wYear,wMonth,wDay:WORD;
  i,j:integer;
  wBigSmallDist,wLeap,wCount,wLeapShift:WORD;
label OK;
begin
  result := 0;
  iDayLeave := Trunc(dtGreg) - cstDateOrg;
  DecodeDate(IncMonth(dtGreg,-1),wYear,wMonth,wDay);
  if (iDayLeave < 0) or (iDayLeave > 22295 )then Exit;
              //Raise Exception.Create('目前只能算1990-01-27以后的');
              //Raise Exception.Create('目前只能算2051-02-11以前的');
  for i:=Low(cstCNTable)   to High(cstCNTable) do begin
      wBigSmallDist := cstCNTable[i];
      wLeap := wBigSmallDist shr 12;
      if wLeap > 12 then begin
          wLeap := wLeap and 7;
          wLeapShift := 1;
      end else
          wLeapShift := 0;
      for j:=1 to 12 do begin
          wCount:=(wBigSmallDist and 1) + 29;
          if j=wLeap then wCount := wCount - wLeapShift;
          if iDayLeave < wCount   then begin
              Result := (i shl 9) + (j shl 5) + iDayLeave + 1;
              Exit;
          end;
          iDayLeave := iDayLeave - wCount;
          if j=wLeap then begin
              wCount:=29 + wLeapShift;
              if iDayLeave < wCount   then begin
                  Result := (i shl 9) + (j shl 5) + iDayLeave + 1 + (1 shl 21);
                  Exit;
              end;
              iDayLeave := iDayLeave - wCount;
          end;
          wBigSmallDist := wBigSmallDist shr 1;
      end;
  end;
//返回值:
// 1位閏月標志 + 12位年份+4位月份+5位日期             (共22位)
end;

function isCNLeap(cnDate:TCNDate):boolean;
begin
  result := (cnDate and $200000) <> 0;
end;

function GetGregDateFromCN(cnYear,cnMonth,cnDay:word;bLeap:Boolean=False):TDateTime;
var
  i,j:integer;
  DayCount:integer;
  wBigSmallDist,wLeap,wLeapShift:WORD;
begin
  // 0101 010010101111     高四位是閏月位置,后12位表示大小月,大月30天,小月29天,
  DayCount := 0;
  if (cnYear < 1990) or (cnYear >2050) then begin
      Result := 0;
      Exit;
  end;
  for i:= cstCNYearOrg to cnYear-1 do begin
        wBigSmallDist := cstCNTable[i];
        if (wBIgSmallDist and $F000) <> 0 then DayCount := DayCount + 29;
        DayCount := DayCount + 12 * 29;
        for j:= 1 to 12 do begin
            DayCount := DayCount + wBigSmallDist and 1;
            wBigSmallDist := wBigSmallDist shr 1;
        end;
  end;
  wBigSmallDist := cstCNTable[cnYear];
  wLeap := wBigSmallDist shr 12;
  if wLeap > 12 then begin
      wLeap := wLeap and 7;
      wLeapShift := 1;                       //大月在閏月.
  end else
      wLeapShift := 0;
  for j:= 1 to cnMonth-1 do begin
      DayCount:=DayCount + (wBigSmallDist and 1) + 29;
      if j=wLeap then DayCount := DayCount + 29;
      wBigSmallDist := wBigSmallDist shr 1;
  end;
  if bLeap and (cnMonth = wLeap)   then   //是要閏月的嗎?
      DayCount := DayCount + 30 - wLeapShift;
  result := cstDateOrg + DayCount + cnDay - 1;
end;

//將日期顯示成農歷字符串.
function GregDateToCNStr(dtGreg:TDateTime):String;
const hzNumber:array[0..10] of string=('零','一','二','三','四','五','六','七','八','九','十');
function ConvertYMD(Number:Word;YMD:Word):string;
var
  wTmp:word;
begin
  result := '';
  if YMD = 1 then begin //年份
      while Number > 0 do begin
          result := hzNumber[Number Mod 10] + result;
          Number := Number DIV 10;
      end;
      Exit;
  end;
  if Number<=10 then begin   //可只用1位
      if YMD = 2 then //月份
          result := hzNumber[Number]
      else                       //天
          result := '初' + hzNumber[Number];
      Exit;
  end;
  wTmp := Number Mod 10;   //個位
  if wTmp <> 0 then result := hzNumber[wTmp];
  wTmp := Number Div 10;           //十位
  result:='十'+result;
  if wTmp > 1 then   result := hzNumber[wTmp] + result;
end;
var
  cnYear,cnMonth,cnDay:word;
  cnDate:TCNDate;
  strLeap:string;
begin
  cnDate:= DecodeGregToCNDate(dtGreg);
  if cnDate = 0 then begin
      result := '輸入越界';
      Exit;                
  end;
  cnDay := cnDate and $1F;
  cnMonth := (cnDate shr 5) and $F;
  cnYear := (cnDate shr 9) and $FFF;
  //測試第22位,為1表示閏月
  if isCNLeap(cnDate) then strLeap:='(閏)' else   strLeap := '';
  result := '農歷' + ConvertYMD(cnYear,1) + '年' + ConvertYMD(cnMonth,2) + '月'
                + strLeap + ConvertYMD(cnDay,3) ;
end;

end.

//////////////////////////  應用 /////////////////////////////
uses CNYear;

PRocedure TForm1.Button1Click(Sender: TObject);
begin
  edit1.text:=GregDateToCNStr(DateTimePicker1.date);
end;


上一篇:Delphi編寫組件封裝asp代碼的基本步驟(Asp組件系列)

下一篇:Delphi動態創建樹

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網友關注

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩视频免费中文字幕| 日韩av日韩在线观看| 亚洲tv在线观看| 日韩在线资源网| 国产美女精品视频| 亚洲色图偷窥自拍| 亚洲午夜精品久久久久久久久久久久| 亚洲国产精品99久久| 欧美多人乱p欧美4p久久| 国产成人亚洲综合青青| 亚洲国产精品久久91精品| 91最新在线免费观看| 91精品久久久久久久| 亚洲国内高清视频| 日本国产一区二区三区| 国产综合色香蕉精品| 亚洲人成欧美中文字幕| 国产日韩欧美日韩大片| 性欧美在线看片a免费观看| 欧美日韩在线观看视频| 影音先锋欧美精品| 91在线国产电影| 一区二区亚洲欧洲国产日韩| 日韩免费在线观看视频| 日韩欧美在线观看| 欧美中文在线免费| 亚洲欧洲一区二区三区在线观看| 欧美日韩亚洲一区二区| 成人午夜小视频| 欧美激情视频在线免费观看 欧美视频免费一| 久久国内精品一国内精品| 成人免费视频网址| 亚洲一区二区三区在线免费观看| 欧美成人激情图片网| 亚洲综合自拍一区| 亚洲另类欧美自拍| 欧美理论片在线观看| 久久久亚洲欧洲日产国码aⅴ| 国产精品无码专区在线观看| 亚洲国产精品va在线看黑人| 国产91精品久久久久久| 色哟哟网站入口亚洲精品| 亚洲老头同性xxxxx| 日韩精品福利网站| 91精品视频播放| 久久久久久久国产精品视频| 国产精品久久久久久久久久新婚| 国产亚洲欧美另类中文| 亚洲精品影视在线观看| 91精品国产高清| 成人激情视频在线观看| 欧美大全免费观看电视剧大泉洋| 欧美极品少妇xxxxⅹ裸体艺术| 久久久久久91香蕉国产| 日韩欧美在线免费| 国产亚洲欧洲高清| 午夜精品美女自拍福到在线| 国产丝袜一区二区| 国产在线视频不卡| 中文字幕亚洲在线| 欧美精品aaa| 一区二区三区www| 国产精品视频中文字幕91| 日本精品免费观看| 红桃av永久久久| 国产亚洲精品美女久久久久| 一本色道久久综合狠狠躁篇怎么玩| 亚洲人在线视频| 欧美激情在线狂野欧美精品| 国产一区二区三区精品久久久| 欧美放荡办公室videos4k| 国产日韩欧美夫妻视频在线观看| 韩日精品中文字幕| 国产精品久久久久7777婷婷| 亚洲精品国产精品自产a区红杏吧| 久久精品中文字幕免费mv| 亚洲性线免费观看视频成熟| 亚洲电影免费观看高清| 91精品国产综合久久香蕉| 国产成人精品午夜| 91精品久久久久久久久久久久久| 久久久久久噜噜噜久久久精品| 亚洲人午夜精品免费| 57pao国产精品一区| 97视频在线观看视频免费视频| 成人h猎奇视频网站| 97国产精品人人爽人人做| 亚洲精品丝袜日韩| 亚洲欧美日韩天堂| 4388成人网| 岛国av一区二区| 亚洲国产精久久久久久| 不卡av日日日| 中文字幕在线亚洲| 欧美成人精品xxx| 久久97久久97精品免视看| 欧美肥臀大乳一区二区免费视频| 国产一区二区三区在线观看网站| 在线播放日韩专区| 欧美在线不卡区| 精品国产欧美成人夜夜嗨| 日韩专区在线观看| 黑人巨大精品欧美一区免费视频| 宅男66日本亚洲欧美视频| 2019中文字幕在线观看| 欧美人在线观看| 亚洲精品日韩激情在线电影| 国产精品免费久久久| 亚洲国产精品久久久久| 国产亚洲aⅴaaaaaa毛片| 亚洲色图五月天| 亚洲国产精彩中文乱码av| 亚洲国产一区二区三区四区| 欧美—级a级欧美特级ar全黄| 精品久久久久久久久久久久| 成人97在线观看视频| 欧美性猛交xxxx免费看久久久| 国产精品一久久香蕉国产线看观看| 亚洲图片制服诱惑| 欧美人与性动交a欧美精品| 色老头一区二区三区在线观看| 久久视频在线观看免费| 成人女保姆的销魂服务| 久久精品亚洲精品| 亚洲一区二区三区乱码aⅴ蜜桃女| 欧美国产极速在线| www.久久撸.com| 国产精品福利片| 日韩中文字幕视频在线| 国产精品视频网| 欧美成人亚洲成人日韩成人| 日韩久久免费电影| 日韩成人av网| 伊人久久免费视频| 影音先锋日韩有码| 日本国产欧美一区二区三区| 亚洲免费福利视频| 九九热这里只有精品6| 亚洲激情在线观看| 一个人www欧美| 亚洲精品久久久久国产| 久久99国产精品久久久久久久久| 国产成人一区二区在线| 久久久国产视频| 97视频网站入口| 日韩精品有码在线观看| 国产va免费精品高清在线| 亚洲日本欧美中文幕| 色www亚洲国产张柏芝| 成人羞羞国产免费| 久久手机精品视频| 91精品国产91久久久| 亚洲精品99久久久久中文字幕| 日韩电影中文字幕| 精品性高朝久久久久久久| 国产精品国产亚洲伊人久久| 亚洲第一在线视频| 亚洲香蕉伊综合在人在线视看| 福利视频导航一区| 欧洲美女7788成人免费视频| 色偷偷88888欧美精品久久久| 国产精品久久久久av| 日本国产欧美一区二区三区| 中文字幕亚洲一区|