关键词搜索

源码搜索 ×
×

vb.net 教程 20-1 农历 2

发布2021-09-15浏览315次

详情内容

版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。

在上一节,我们学习了 ChineseLunisolarCalendar类的简单用法,但是最终获得的结果不是那么符合国人的习俗。

例如,农历的2017年1月23日往往写做: 二O一七年正月廿三日。这一节将完善上一节的结果。

界面还是上一节一样。

主要代码:

    Dim chineseCallDay() As String = {"", "一", "二", "三", "四", "五", "六", "七", "八", "九"}

    Dim chineseCallMonth() As String = {"正", "二", "三", "四", "五", "六", "七", "八", "九", "十", "十一", "腊"}

    Dim chineseCallYear() As String = {"〇", "一", "二", "三", "四", "五", "六", "七", "八", "九"}

    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click

        Dim chineseCalendar As New ChineseLunisolarCalendar

        Dim nowdate As DateTime = New DateTime(2017, 2, 19)

        Dim chineseY As Integer = chineseCalendar.GetYear(nowdate)

        Dim chineseM As Integer = chineseCalendar.GetMonth(nowdate)

        Dim chineseD As Integer = chineseCalendar.GetDayOfMonth(nowdate)

        Dim leapMonth As Integer = chineseCalendar.GetLeapMonth(chineseY)

        Dim isLeap As Boolean = False

        If leapMonth > 0 Then

            If leapMonth = chineseM Then

                isLeap = True

                chineseM -= 1

            ElseIf chineseM > leapMonth Then

                chineseM -= 1

            End If

        End If

        TextBox1.Text = getChineseYear(chineseY) & "年" & IIf(isLeap, "闰", "") & getChineseMonth(chineseM) & "月" & getChineseDay(chineseD)

    End Sub

    Private Function getChineseDay(ByVal theDay As Integer) As String

        Dim callDay As String

        If theDay < 10 Then

            callDay = "初" & chineseCallDay(theDay)

            Return callDay

        End If

        If theDay >= 10 And theDay < 20 Then

            callDay = "十"

            callDay &= chineseCallDay(theDay Mod 10)

            Return callDay

        End If

        If theDay >= 20 And theDay < 30 Then

            callDay = "廿"

            callDay &= chineseCallDay(theDay Mod 10)

            Return callDay

        End If

        If theDay >= 30 Then

            callDay = "三十"

            callDay &= chineseCallDay(theDay Mod 10)

            Return callDay

        End If

    End Function

    Private Function getChineseMonth(ByVal theMonth As Integer) As String

        Return chineseCallMonth(theMonth - 1)

    End Function

    Private Function getChineseYear(ByVal theYear As Integer) As String

        Dim callYear As String = ""

        Dim strYear As String = CType(theYear, String)

        Dim intMidYear As Integer

        For i As Integer = 0 To strYear.Length - 1

            intMidYear = Integer.Parse(strYear.Substring(i, 1))

            callYear &= chineseCallYear(intMidYear)

        Next

        Return callYear

    End Function

同时结果还说明了是不是闰月,代码比较简单,不在解说。

运行结果,2017年2月19对应的农历:

学习更多vb.net知识,请参vb.net教程目录

版权声明:本文为CSDN博主「VB.Net」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

 

相关技术文章

点击QQ咨询
开通会员
返回顶部
×
微信扫码支付
微信扫码支付
确定支付下载
请使用微信描二维码支付
×

提示信息

×

选择支付方式

  • 微信支付
  • 支付宝付款
确定支付下载