设为首页 收藏本站
查看: 599|回复: 0

[经验分享] 四分历python实现

[复制链接]

尚未签到

发表于 2015-12-1 10:24:26 | 显示全部楼层 |阅读模式
  根据一个新加坡人的c代码改写成python代码
  



  1 ''' 四分历'''
  2
  3 #
  4 zq = 0
  5 month = 0
  6
  7 def main():
  8     global month
  9     year = 1
10     rb_year = 0
11     moon = 0  # number of new moon since beginning of ru bu year.
12     tmonth = 0
13     continues = False
14
15     while year != 0:
16         year = int(input("\nPlease Enter a year to do computation (range:85~236, 0 to exit):"))
17
18         if year == 0:
19             return
20         if year < 85 or year > 236:
21             print("\nCalculation of Si Fen Li doesn't apply to your input value.")
22             input("\nPress Enter to continue.")
23             #getch(continues);
24             continue
25
26         rb_year = (year + 9281) % 76
27         tmonth = 14 + Leap_y(rb_year)
28
29         print("月\t朔\t望\t长度\t中气\t时间\t时间\t时间")
30         print("- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -")
31
32         month = 11
33         #zq = 0
34         for moon in range(1, tmonth + 1):
35             if moon % 8 == 0:
36                 #print("\n")
37                 pass
38             print_s(rb_year, moon)
39             month += 1
40             if month > 12:
41                 month = 1
42
43         input("\nPress Enter to continue.")
44
45 # 润年
46 def Leap_y( rbyear):
47     isLeap = 0
48     if ((rbyear - 1) * 235 ) % 19 >= 12:
49         isLeap = 1
50     return isLeap
51
52 # 润月
53 def Leap_m(rbyear, month):
54     isLeap = 0
55     completed_month = (rbyear - 1) * (235.0/19.0) + (month - 1)
56     acd_first = (completed_month * (29.0+499.0/940.0) )
57     acd_last  = ((completed_month + 1.0) * (29.0+499.0/940.0) )
58     qi_first  = int(acd_first)/(30.0+14.0/32.0)
59     qi_last   = int(acd_last) / (30.0+14.0/32.0)
60
61     if qi_first - int(qi_first) != 0:
62         if int(qi_first) == int(qi_last) or qi_last == int(qi_last):
63             isLeap = 1
64
65     return isLeap
66
67
68 # 打印结果
69 def print_s(rbyear, moon):
70     global zq
71     global month
72     name_s = acd_shuo(rbyear, moon)
73     name_w = acd_wang(rbyear, moon)
74     time_s = ( acd_shuo(rbyear, moon) - float(name_s) ) * 24.0
75     time_w = ( acd_wang(rbyear, moon) - float(name_w) ) * 24.0
76     length = int(acd_shuo(rbyear, moon + 1)) - name_s
77
78     if Leap_m(rbyear, moon) == 0:    #if is not a leap month.
79         zq += 1
80         name_q = acd_qi(rbyear, zq);
81         time_q = ( acd_qi(rbyear, zq) - (float)(name_q) ) * 24.0
82         print("{}\t1\t{:.1f}\t{:.3f}\t{:.1f}\t{:.3f}\t{:.3f}\t{:.1f}".format(month, time_s, name_w - name_s + 1, time_w, length, name_q - name_s + 1, time_q))
83     else:
84         month -= 1
85         print("{}(Leap)\t1\t{:.1f}\t{:.3f}\t{:.1f}\t{:.3f}".format(month, time_s, name_w - name_s + 1, time_w, length))
86
87
88 # 朔
89 def acd_shuo(rbyear, moon):
90     completed_month = ((rbyear - 1) * 235 / 19) + moon - 1
91     return completed_month * (29.0+499.0/940.0)
92
93 # 望
94 def acd_wang(rbyear, moon):
95     completed_month = ((rbyear - 1) * 235 / 19) + moon - 1
96     return (completed_month + 0.5) * (29.0+499.0/940.0)
97
98 # 气
99 def acd_qi(rbyear, qi):
100     completed_qi = ((rbyear - 1) * 12) + qi - 1
101     return completed_qi * (30.0+14.0/32.0)
102
103
104 if __name__ == '__main__':
105     main()
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-145760-1-1.html 上篇帖子: Python单元测试框架之pytest 下篇帖子: 用python从符合一定格式的txt文档中逐行读取数据并按一定规则写入excel(openpyxl支持Excel 2007 .xlsx格式)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表