#!/usr/bin/python3.7
# -*- coding:utf-8 -*-

'''
整体思路
1:根据公式算出节气日期 1900 年到 2100  200 年的时间
2:特殊的年份进行纠正
3:保存到文件里去

'''
import sys
import json
import gc
import os

default_encoding = 'utf-8'
if sys.getdefaultencoding() != default_encoding:
    reload(sys)
class jieqi:
    # 计算节气的C常量组
    C_list_21 = [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]

C_list_20 = [4.6295, 19.4599, 6.3826, 21.4155, 5.59,20.888, 6.318, 21.86, 6.5, 22.2, 7.928, 23.65, 8.35,  23.95, 8.44, 23.822, 9.098, 24.218, 8.218, 23.08, 7.9, 22.6, 6.11, 20.84]

# 节气名称组
    name_Arr = ["立春", "雨水", "惊蛰", "春分", "清明", "谷雨", "立夏", "小满", "芒种", "夏至", "小暑", "大暑", "立秋", "处暑", "白露", "秋分", "寒露", "霜降", "立冬", "小雪", "大雪", "冬至", "小寒", "大寒"]

def __init__(self):
        self.c_list=[]

## 特殊年份特殊节气进行纠正
    def rectify_year(self,year,jieqiid,day):
        ## 特殊年份
        rectify_year = [2026,2084,1911,2008,1902,1928,1925,2016,1922,2002,1927,1942,2089,2089,1978,1954,1918,2021,1982,2082,2019,2021]
        ## 特殊节气
        rectify_jieqi = [1,3,6,7,8,9,10,10,11,12,14,15,17,18,19,20,21,21,22,22,23]
        ## 偏移量
        rectify_offset = [-1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,-1,-1,1,-1,1]
        pop2 = -1
        if year in rectify_year:
            if year == 2089:
                pop1 = rectify_year.index(year) ## 找到位置
                pop2 = pop1+1
            else:
                pop1 = rectify_year.index(year) ## 找到位置

if rectify_jieqi[pop1] == jieqiid:
                day = day + int(rectify_offset[pop1])
            if rectify_jieqi[pop2] == jieqiid:
                day = day + int(rectify_offset[pop2])
        return day

#计算节气日期,并创建文件
    def creat_year_jieqi(self,year):
            year_pre = year//100
            if year_pre == 19:
                C_arr = self.C_list_20
            elif year_pre == 20:
                C_arr = self.C_list_21

year_num = year%100
            list_arr = []
            for i in range(0, 24):
                C = C_arr[i]
                ## 注意:凡闰年3月1日前闰年数要减一,即:L=[(Y-1)/4],因为小寒、大寒、立春、雨水这两个节气都小于3月1日,所以 y = y-1
                if i == 0 or i == 1 or i == 22 or i == 23:
                    if self.comrun(year):
                        days = (year_num * 0.2422 + C) // 1 - ((year_num-1)// 4)
                    else:
                        days = (year_num * 0.2422 + C) // 1 - (year_num // 4)
                else:
                    days = (year_num * 0.2422 + C) // 1 - (year_num // 4)

## 特殊年份节气进行纠正
                days = self.rectify_year(year,i,days)

days = int(days)
                days = '%02d' % days
                y = int(year_num // 1)
                m = i // 2 + 2
                if m == 13:
                    m = 1
                m = '%02d' % m
                y = '%02d' % y
                strs = "{3}{0}-{1}-{2} 00:00:00".format(str(y), str(m), str(days),str(year_pre))
                item = dict(name=self.name_Arr[i], jieqiid=str(i + 1), time=strs)
                # print (item)
                list_arr.append(item)
            list_str = json.dumps(list_arr,ensure_ascii=False) ## 中文不进行编码
            file_name = "./json/{0}.json".format(str(year))
            with open(file_name, "w",encoding="utf-8") as f:  ## 打开时用 utf-8 编码
                json.dump(list_str, f,ensure_ascii=False)
                print("{0}已载入文件完成...".format(str(year)))

# 读取年份为 name 年的节气数据
    def read_json_file(self,name):
        json_file = open('./json/' + name + '.json', 'r',encoding="utf-8")
        json_str = json_file.read()
        dic = json.loads(json_str)
        print(dic)

# 读取测试
    # read_json_file('2029')

# 读取所有年份的节气数据
    def check_all_file(self):
        for index in range(1900, 2100):
            c_file_name = './json/{0}.json'.format(str(index))
            if os.path.isfile(c_file_name):
                json_file = open(c_file_name, 'r',encoding="utf-8")
                json_str = json_file.read()
                dic = json.loads(json_str)
                print (str(index) + dic)
    ## 算是否是闰年
    def comrun(self,year):
        i = 0
        if (year % 4) != 0 :
            i=0
        elif ((year % 100) == 0) & ((year % 400) != 0):
            i=0
        else:
            i=1
        return i

jieqi = jieqi()

#jieqi.creat_year_jieqi(2004)
#jieqi.read_json_file('2006')
#jieqi.check_all_file()
#
#for i in range(1900,2100):
#   jieqi.creat_year_jieqi(i)

python 生成 1900-2100 的二十四节气文件相关推荐

  1. Python生成Windows可执行exe文件

    环境 python3.6.5 pyinstaller3.5 windows 10 下载地址 python:https://www.python.org/ftp/python/3.6.5/python- ...

  2. Python生成简易用户名及密码文件

    import redef generate_easy_username_password():"""生成简易用户名和密码:return:""" ...

  3. 利用python生成微信h5_Python的h5文件的创建与读取

    代码流程图:本章代码流程 这章是关于--make_dataset.py的 -------------------------------①------------------------------ ...

  4. python自动生成html_PyH : python生成html

    样例 下面是官网的一个例子: from pyh import * page = PyH('My wonderful PyH page') page.addCSS('myStylesheet1.css' ...

  5. python 节气计算_python 生成 1900-2100 的二十四节气文件

    [学习笔记] 转载 #!/usr/bin/python3.7 # -*- coding:utf-8 -*- ''' 整体思路 1:根据公式算出节气日期 1900 年到 2100  200 年的时间 2 ...

  6. 1900页Python系列PPT分享七:文件操作(132页)

    总体说明:本套PPT共约1900页,包含董付国老师Python系列图书<Python程序设计基础>(2017年7月第5次印刷).<Python程序设计(第2版)>(2018年1 ...

  7. python使用fpdf生成发票格式的pdf文件包含:文字、图片logo、表格、条形码等;

    python使用fpdf生成发票格式的pdf文件包含:文字.图片logo.表格.条形码等: pip install fpdf #python使用fpdf生成发票格式的pdf文件包含:文字.图片logo ...

  8. windows平台 python生成 pyd文件

    Python的文件类型介绍: .py       python的源代码文件 .pyc     Python源代码import后,编译生成的字节码 .pyo     Python源代码编译优化生成的字节 ...

  9. python生成xml文件工具_Python根据指定文件生成XML的方法

    因项目需要根据指定格式的文件生成XML标注文件,可以方便使用LabelImg打开进行编辑和查看.其原始文件默认使用逗号进行分隔,如下所示: 第1个值:原始图片中切图小文件,以AIpng_x,其中x代表 ...

最新文章

  1. 微信小程序点击页面tab栏切换
  2. sqlserver安装时尽量少的占用c盘_安装3dmax出现command line option 报错,如何解决
  3. pytorch无法下载或下载缓慢问题
  4. webpack 4.0 小记
  5. ASP.NET跨页传值方法汇总
  6. Python可视化 | Seaborn(01)
  7. java 判断文件是否打开过_【后端开发】Java中如何判断文件是否被隐藏?(代码示例)...
  8. 一维搜索——进退法matlab实现(含代码)
  9. OpenCV2.4.13+CUDA8.0+SSBA3.0+VS2010编译安装
  10. 转并学习: 将rar文件转换为zip格式
  11. dell服务器设置bios设置u盘启动不了系统,详解戴尔通过BIOS设置U盘启动的技巧
  12. vscode插件 中文一键转英文并生成多种命名格式 提效神器
  13. 二级C语言office公共基础知识点
  14. linux 中的rime 输入法 自定义 新世纪五笔输入法
  15. baq在聊天中啥意思,Epicor 10在BPM工作流设计器中链接BAQ(避免自定义代码)
  16. 安徽农村信用社网银转账显示服务器无响应,农村信用社企业网银转账显示状态无效是怎么回事...
  17. B2B-Destoon--注册会员公司名称修改方法
  18. 取消小米笔记本插入耳机后弹框
  19. 数据挖掘mooc国防科技大学笔记(自留)
  20. Java实现多种情况下语言本地化

热门文章

  1. java web入门经典 pdf_Java Web入门经典 (王国辉陈英) PDF
  2. Word文档忘记密码怎么办?
  3. 404 not found 背后的布道师
  4. 成绩分析系统php,考试成绩分析系统的设计与实现(有源程序代码)(可编辑).doc...
  5. DevOps基础-4.1-基础架构自动化:基础设施即代码
  6. ubuntu中U盘硬盘格式化NTFS
  7. MATLAB中调制解调器,程序代码~MATLAB仿真 BPSK调制解调器
  8. Agora 教程丨一个典型案例,教你如何使用水晶球“数据洞察”
  9. 托盘垃圾广告软件追踪
  10. 深度学习框架人脸识别介绍