python万年历节气_用Python精确计算100年内二十四节气日期
这两天在做万年历app的项目,其中有一项需要获得二十四节气的精确日期。
因为这个二十四节气日期在项目中用到的地方比较多(主要是精确计算某一天的年月日天干这方面);而且二十四节气计算的具体情况又特别复杂,还有十几个例外情况。
就想着提前计算好100年的二十四节气具体日期,做成json文件,存储在前端。这样,一来可以减少前端的计算压力,二来可以提前做好精确计算和校对,防止前端计算失误。
此外,100年,每年24条,总共2400条数据,这个以json文件的形式存储,存取速度,内存占用都是足够的。但,实际情况是,某一年仅有24条数据,而在同一时间段内,仅访问这一年的24条数据的频率会很高,即访问效率并不平均。
所以,就计划分年份生成json文件,通过批处理,生成100 个json文件,以年份为文件命名,既方便核对相关数据正确性,又可以降低文件大小以及前端读取文件的性能压力。
下面是代码:
# -*- coding:utf-8 -*-
import sys
import json
import urllib2
import gc
default_encoding = 'utf-8'
if sys.getdefaultencoding() != default_encoding:
reload(sys)
# 读取年份为 name 年的节气数据
def read_json_file(name):
json_file = open('JSON/' + name + '.json', 'r')
json_str = json_file.read()
dic = json.loads(json_str)
print dic
# 读取测试
# read_json_file('2029')
# 读取所有年份的节气数据
def check_all_file():
for index in range(2000, 2100):
c_file_name = 'JSON/{0}.json'.format(str(index))
json_file = open(c_file_name, 'r')
json_str = json_file.read()
dic = json.loads(json_str)
print (str(index) + dic)
# 计算节气的C常量组
C_Arr = [3.87, 18.73, 5.63, 20.646, 4.81, 20.1,
5.52, 21.04, 5.678, 21.37, 7.108, 22.83,
7.5, 23.13, 7.646, 23.042, 8.318, 23.438,
7.438, 22.36, 7.18, 21.94, 5.4055, 20.12]
# 节气名称组
name_Arr = ["立春", "雨水", "惊蛰", "春分", "清明", "谷雨",
"立夏", "小满", "芒种", "夏至", "小暑", "大暑",
"立秋", "处暑", "白露", "秋分", "寒露", "霜降",
"立冬", "小雪", "大雪", "冬至", "小寒", "大寒"]
#循环100年,计算节气日期,并创建文件
def creat_all_year():
# type: () -> null
for year in range(00, 99):
list_arr = []
for i in range(0, 24):
C = C_Arr[i]
if i == 0 or 1 or 10 or 11:
days = (year * 0.2422 + C) // 1 - ((year - 1) // 4)
else:
days = (year * 0.2422 + C) // 1 - (year // 4)
days = int(days)
days = '%02d' % days
y = int(year // 1)
m = i // 2 + 2
if m == 13:
m = 1
m = '%02d' % m
y = '%02d' % y
strs = "20{0}-{1}-{2} 00:00:00".format(str(y), str(m), str(days))
item = dict(name=name_Arr[i], jieqiid=str(i + 1), time=strs)
# print (item)
list_arr.append(item)
list_str = json.dumps(list_arr)
file_name = "JSON/20{0}.json".format(str(year))
with open(file_name, "w") as f:
json.dump(list_str, f)
print("20{0}已载入文件完成...".format(str(year)))
creat_all_year()
运行log如下:
屏幕快照 2017-11-21 下午5.27.59.png
实际文件:
屏幕快照 2017-11-21 下午5.28.35.png
其中的一个文件内容如下:
屏幕快照 2017-11-21 下午5.29.31.png
然后再跟网上主流的节气数据核对核对,手动更改掉计算方法提到的例外情况,就形成了100个完好可用的json文件。
核对地址如下:
https://jieqi.911cha.com/2099.html
当然还有一种方法就是通过爬虫,不断的遍历这个网站的所以年份,就省去了计算核对的麻烦。五脸懵逼中~~!
搞完收工!
python万年历节气_用Python精确计算100年内二十四节气日期相关推荐
- python万年历制作_利用Python制作万年历
第一个Python小程序,制作简易万年历.现在开始学习Python的目的主要是为了学习人工智能 写这个小程序的目的主要是了解一下Python的简单语法使用,其实写这个程序之前,我还没有看Python的 ...
- python万年历节气_万年历API接口_免费数据接口 - 极速数据
package api.jisuapi.calendar; import api.util.HttpUtil; import net.sf.json.JSONArray; import net.sf. ...
- python 时间序列预测_使用Python进行动手时间序列预测
python 时间序列预测 Time series analysis is the endeavor of extracting meaningful summary and statistical ...
- python 概率分布模型_使用python的概率模型进行公司估值
python 概率分布模型 Note from Towards Data Science's editors: While we allow independent authors to publis ...
- 蒙特卡洛python求解派_用蒙特卡洛方法计算派-python和R语言
标签: 用蒙特卡洛方法算pi-基于python和R语言 最近follow了MOOC上一门python课,开始学Python.同时,买来了概率论与数理统计,准备自学一下统计.(因为被鄙视过不是统计专业却 ...
- 机械专业与python的联系_使用python进行机械设计计算
分析 这一过程的核心在于机械设计,python的编程的用途有两个 1.当作计算器,缺点在于没有casio计算器那样的自然显示,优点在于可以反复调用,使用lambda函数简化运算 2.当设计需要修改时, ...
- python希腊字母字符串_#10 Python字符串
前言 通过上一节可知,Python6个序列的内置类型中,最常见的是列表和元组,但在Python中,最常用的数据类型却不是列表和元组,而是字符串.要想深入了解字符串,必须先掌握字符编码问题.因此本篇博文 ...
- python集群_使用Python集群文档
python集群 Natural Language Processing has made huge advancements in the last years. Currently, variou ...
- python机器学习预测_使用Python和机器学习预测未来的股市趋势
python机器学习预测 Note from Towards Data Science's editors: While we allow independent authors to publish ...
最新文章
- linux修改响应时间,linux下使用httping测试web响应时间
- 如何解决微服务的数据一致性分发问题
- java中employee_java Employee(雇员)
- linux操作系统之子进程回收函数wait和waitpid函数小结
- JAVA面试题,比较经典的面试题
- 收藏的一个关于C# ToString的方法集合
- js带开关的时钟_避雷器带计数器HY5WZ-17/45-JS
- UVA10929 You can say 11【大数模除】
- 使用DevCpp/DevC++调试的设置和步骤
- docker-compose 部署 mindoc文档服务器(支持在线markdown文件编辑)
- c语言怎么取字符串首字母,C语言 字符串首字母转换成大写简单实例
- C++ 操纵算子原理
- 2022-6-5 供暖器,最小差,两地调度,峰与谷
- 蓝桥杯三羊献瑞java_java实现第六届蓝桥杯三羊献瑞
- CSDN、掘金、简书博客文章如何转为Markdown?
- IBM Thinkpad 笔记本型号保修全揭秘(这个全点)
- torch norm() Formalize()
- Java zxing生成vcard二维码名片
- 从互联网跳到国企,本以为上岸了,结果降薪30%,周末要义务加班,所以我图什么?...
- Sketch Mirror使用
热门文章
- LEX自动生成词法分析器
- java设计模式adapter,java设计模式-适配器模式(Adapter)
- 多个安卓设备投屏到电脑_华为手机可以投屏到电脑,那其他安卓手机呢?其实非常简单...
- Python爬虫——爬取壁纸
- ifft matlab报错,傅立叶逆变换ifft之后出现虚数
- 为什么手机信号满格,但网速却还是那么慢?这4点原因是关键
- 畅通工程(并查集 C++)
- 2017华为软件精英挑战赛决赛思路分享
- 用LINQ结合CAML查询 Sharepoint 数据库内容
- 开放原子训练营(第一季)铜锁探密,SM3杂凑算法加强至pro版