欢迎光临
我们一直在努力

vb编程计算农历的计算方法_visualbasic教程

建站超值云服务器,限时71元/月

下面是一个关于VB的农历算法

日期数据定义方法如下

前12个字节代表1-12月为大月或是小月,1为大月30天,0为小月29天,

第13位为闰月的情况,1为大月30天,0为小月29天,第14位为闰月的月

份,如果不是闰月为0,否则给出月份,10、11、12分别用A、B、C来表

示,即使用16进制。最后4位为当年家农历新年-即农历1月1日所在公历

的日期,如0131代表1月31日。

GetYLDate函数使用方式如下tYear为要输入的年,tMonth为月,tDay为

日期,YLyear是返回值,返加农历的年份,如甲子年,YLShuXing返回

的是属象,如鼠。IsGetGl是设置是不是通过农历取公历值,如果是,

前三个返回相应的公历日期,而且返回值是一个公历日期。

FunctionGetYLDate(tYearAsInteger,tMonthAsInteger,tDayAsInteger,_

YLyearAsString,YLShuXingAsString,_

OptionalIsGetGlAsBoolean)AsString

OnErrorResumeNext

DimdaList(1900To2011)AsString*18

DimconDateAsDate,setDateAsDate

DimAddMonthAsInteger,AddDayAsInteger,AddYearAsInteger,getDayAsInteger

DimRunYueAsBoolean

IftYear>2010OrtYear<1901ThenExitFunction如果不是有效有日期,退出

1900to1909

daList(1900)=”010010110110180131″

daList(1901)=”010010101110000219″

daList(1902)=”101001010111000208″

daList(1903)=”010100100110150129″

daList(1904)=”110100100110000216″

daList(1905)=”110110010101000204″

daList(1906)=”011010101010140125″

daList(1907)=”010101101010000213″

daList(1908)=”100110101101000202″

daList(1909)=”010010101110120122″

daList(1910)=”010010101110000210″

daList(1911)=”101001001101160130″

daList(1912)=”101001001101000218″

daList(1913)=”110100100101000206″

daList(1914)=”110101010100150126″

daList(1915)=”101101010101000214″

daList(1916)=”010101101010000204″

daList(1917)=”100101101101020123″

daList(1918)=”100101011011000211″

daList(1919)=”010010011011170201″

daList(1920)=”010010011011000220″

daList(1921)=”101001001011000208″

daList(1922)=”101100100101150128″

daList(1923)=”011010100101000216″

daList(1924)=”011011010100000205″

daList(1925)=”101011011010140124″

daList(1926)=”001010110110000213″

daList(1927)=”100101010111000202″

daList(1928)=”010010010111120123″

daList(1929)=”010010010111000210″

daList(1930)=”011001001011060130″

daList(1931)=”110101001010000217″

daList(1932)=”111010100101000206″

daList(1933)=”011011010100150126″

daList(1934)=”010110101101000214″

daList(1935)=”001010110110000204″

daList(1936)=”100100110111030124″

daList(1937)=”100100101110000211″

daList(1938)=”110010010110170131″

daList(1939)=”110010010101000219″

daList(1940)=”110101001010000208″

daList(1941)=”110110100101060127″

daList(1942)=”101101010101000215″

daList(1943)=”010101101010000205″

daList(1944)=”101010101101140125″

daList(1945)=”001001011101000213″

daList(1946)=”100100101101000202″

daList(1947)=”110010010101120122″

daList(1948)=”101010010101000210″

daList(1949)=”101101001010170129″

daList(1950)=”011011001010000217″

daList(1951)=”101101010101000206″

daList(1952)=”010101011010150127″

daList(1953)=”010011011010000214″

daList(1954)=”101001011011000203″

daList(1955)=”010100101011130124″

daList(1956)=”010100101011000212″

daList(1957)=”101010010101080131″

daList(1958)=”111010010101000218″

daList(1959)=”011010101010000208″

daList(1960)=”101011010101060128″

daList(1961)=”101010110101000215″

daList(1962)=”010010110110000205″

daList(1963)=”101001010111040125″

daList(1964)=”101001010111000213″

daList(1965)=”010100100110000202″

daList(1966)=”111010010011030121″

daList(1967)=”110110010101000209″

daList(1968)=”010110101010170130″

daList(1969)=”010101101010000217″

daList(1970)=”100101101101000206″

daList(1971)=”010010101110150127″

daList(1972)=”010010101101000215″

daList(1973)=”101001001101000203″

daList(1974)=”110100100110140123″

daList(1975)=”110100100101000211″

daList(1976)=”110101010010180131″

daList(1977)=”101101010100000218″

daList(1978)=”101101101010000207″

daList(1979)=”100101101101060128″

daList(1980)=”100101011011000216″

daList(1981)=”010010011011000205″

daList(1982)=”101001001011140125″

daList(1983)=”101001001011000213″

daList(1984)=”1011001001011A0202″

daList(1985)=”011010100101000220″

daList(1986)=”011011010100000209″

daList(1987)=”101011011010060129″

daList(1988)=”101010110110000217″

daList(1989)=”100100110111000206″

daList(1990)=”010010010111150127″

daList(1991)=”010010010111000215″

daList(1992)=”011001001011000204″

daList(1993)=”011010100101030123″

daList(1994)=”111010100101000210″

daList(1995)=”011010110010180131″

daList(1996)=”010110101100000219″

daList(1997)=”101010110110000207″

daList(1998)=”100100110110150128″

daList(1999)=”100100101110000216″

daList(2000)=”110010010110000205″

daList(2001)=”110101001010140124″

daList(2002)=”110101001010000212″

daList(2003)=”110110100101000201″

daList(2004)=”010110101010120122″

daList(2005)=”010101101010000209″

daList(2006)=”101010101101170129″

daList(2007)=”001001011101000218″

daList(2008)=”100100101101000207″

daList(2009)=”110010010101150126″

daList(2010)=”101010010101000214″

daList(2011)=”101101001010000214″

AddYear=tYear

RunYue=False

IfIsGetGlThen

AddMonth=Val(Mid(daList(AddYear),15,2))

AddDay=Val(Mid(daList(AddYear),17,2))

conDate=DateSerial(AddYear,AddMonth,AddDay)

AddDay=tDay

Fori=1TotMonth-1

AddDay=AddDay 29 Val(Mid(daList(tYear),i,1))

Nexti

MsgBoxDateDiff(“d”,conDate,Date)

setDate=DateAdd(“d”,AddDay-1,conDate)

GetYLDate=setDate

tYear=Year(setDate)

tMonth=Month(setDate)

tDay=Day(setDate)

ExitFunction

EndIf

CHUSHIHUA:

AddMonth=Val(Mid(daList(AddYear),15,2))

AddDay=Val(Mid(daList(AddYear),17,2))

conDate=DateSerial(AddYear,AddMonth,AddDay)

setDate=DateSerial(tYear,tMonth,tDay)

getDay=DateDiff(“d”,conDate,setDate)

IfgetDay<0ThenAddYear=AddYear-1:GoToCHUSHIHUA

addday=NearDay

AddDay=1:AddMonth=1

Fori=1TogetDay

AddDay=AddDay 1

IfAddDay=30 Mid(daList(AddYear),AddMonth,1)Or(RunYueAndAddDay=30 Mid(daList(AddYear),13,1))Then

IfRunYue=FalseAndAddMonth=Val(“&H”&Mid(daList(AddYear),14,1))Then

RunYue=True

Else

RunYue=False

AddMonth=AddMonth 1

EndIf

AddDay=1

EndIf

Next

md$=”初一初二初三初四初五初六初七初八初九初十十一十二十三十四十五十六十七十八十九二十廿一廿二廿三廿四廿五廿六廿七廿八廿九三十”

dd$=Mid(md$,(AddDay-1)*2 1,2)

mm$=Mid(“正二三四五六七八九十寒腊”,AddMonth,1) “月”

YouGetDate=DateSerial(AddYear,AddMonth,AddDay)

tiangan$=”甲乙丙丁戊已庚辛壬癸”

dizhi$=”子丑寅卯辰巳午未申酉戌亥”

Dimganzhi(0To59)AsString*2

Fori=0To59

ganzhi(i)=Mid(tiangan$,(iMod10) 1,1) Mid(dizhi$,(iMod12) 1,1)

ff$=ff$ ganzhi(i)

Nexti

MsgBoxff$,,Len(ff$)

YLyear=ganzhi((AddYear-4)Mod60)

shu$=”鼠牛虎兔龙蛇马羊猴鸡狗猪”

YLShuXing=Mid(shu$,((AddYear-4)Mod12) 1,1)

IfRunYueThenmm$=”闰” mm$

GetYLDate=mm$ dd$

EndFunction

下面是一个使用的例子,你需要在窗体上加上一个按扭,并命名为Command1,然后将下列代码复制到窗体的代码中

PrivateSubCommand1_Click()

DimtyAsInteger,tmAsInteger,tdAsInteger,ylAsString,sxAsString

取公历1999年10月28日的农历日期

ty=1999

tm=10

td=28

t=GetYLDate(ty,tm,td,yl,sx)

MsgBoxt

MsgBoxty&”-“&tm&”-“&td&””&yl&””&sx

取1999年农历十月28的公历日期

t=GetYLDate(ty,tm,td,yl,sx,True)

MsgBoxt

MsgBoxty&”-“&tm&”-“&td&””&yl&””&sx

EndSub->

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » vb编程计算农历的计算方法_visualbasic教程
分享到: 更多 (0)