公历转为农历的函数

/// <summary>
    /// 公历转为农历的函数
    /// </summary>
    /// <param name="solarDateTime">公历日期</param>
    /// <returns>农历的日期</returns>
    static string SolarToChineseLunisolarDate(DateTime solarDateTime)
    {
        System.Globalization.ChineseLunisolarCalendar cal = new System.Globalization.ChineseLunisolarCalendar();

        int year = cal.GetYear(solarDateTime);
        int month = cal.GetMonth(solarDateTime);
        int day = cal.GetDayOfMonth(solarDateTime);
        int leapMonth = cal.GetLeapMonth(year);
        //return string.Format("农历{0}{1}({2})年{3}{4}月{5}{6}"
        //                    , "甲乙丙丁戊己庚辛壬癸"[(year - 4) % 10]
        //                    , "子丑寅卯辰巳午未申酉戌亥"[(year - 4) % 12]
        //                    , "鼠牛虎兔龙蛇马羊猴鸡狗猪"[(year - 4) % 12]
        //                    , month == leapMonth ? "闰" : ""
        //                    , "无正二三四五六七八九十冬腊"[leapMonth > 0 && leapMonth <= month ? month - 1 : month]
        //                    , "初十廿三"[day / 10]
        //                    , "日一二三四五六七八九"[day % 10]
        //                    );
        return string.Format("农历{0}月{1}{2}"
                            , "无正二三四五六七八九十冬腊"[leapMonth > 0 && leapMonth <= month ? month - 1 : month]
                            , "初十廿三"[day / 10]
                            , "日一二三四五六七八九"[day % 10]
                            );
    }

要编写Excel公历农历函数代码,可以遵循以下步骤: 1. 定义公历农历的数据表:首先,需要创建一个公历农历的数据表,该表包含了每个公历日和对应的农历日。可以从互联网上搜索到这样的表,或者使用已有的开源数据。 2. 导入数据表:将公历农历的数据表导入Excel,确保数据表中的每一列有一个唯一的标识符,如公历日期和农历日期。 3. 创建VLOOKUP函数:在Excel中,可以使用VLOOKUP函数来查找公历日期并返回对应的农历日期。语法为:VLOOKUP(lookup_value, table_array, col_index_num, range_lookup)。其中,lookup_value是待查找的公历日期,table_array是导入的数据表范围,col_index_num是农历日期所在的列号,range_lookup设置为FALSE表示精确匹配。 4. 结合DATE函数:如果要将公历日期拆分为年、月和日,并转换为对应的农历日期,可以结合DATE函数和VLOOKUP函数。例如,DATE函数用于将年、月和日作为参数,返回对应的公历日期,然后使用VLOOKUP函数公历日期转换为农历日期。 5. 自定义函数:可以将上述步骤封装为一个自定义函数,以便在Excel中直接调用。自定义函数包含输入参数,例如公历日期,然后执行上述步骤,并返回农历日期。 通过以上步骤,可以编写一个Excel公历农历函数代码。具体实现方式取决于具体的数据表和需求,并可能需要进行一些调整和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值