Python生成日历导出Excel

python 复制代码
import openpyxl
from openpyxl.styles import Font, Alignment, Border, Side, PatternFill, NamedStyle
from openpyxl.utils import get_column_letter
from datetime import datetime, date, timedelta
from calendar import monthcalendar, month_abbr
import holidays
import os
# 创建中国节假日对象
cn_holidays = holidays.CN(years=2025)

# 创建工作簿
wb = openpyxl.Workbook()
wb.remove(wb.active)  # 删除默认sheet

# 定义样式
header_style = NamedStyle(name="header_style")
header_style.font = Font(bold=True, color="FFFFFF", size=12)
header_style.fill = PatternFill(start_color="4472C4", fill_type="solid")
header_style.alignment = Alignment(horizontal="center", vertical="center")
header_style.border = Border(left=Side(style='thin'), right=Side(style='thin'),
                             top=Side(style='thin'), bottom=Side(style='thin'))

weekend_style = NamedStyle(name="weekend_style")
weekend_style.font = Font(color="FF0000", bold=True)
weekend_style.fill = PatternFill(start_color="F2F2F2", fill_type="solid")

holiday_style = NamedStyle(name="holiday_style")
holiday_style.font = Font(color="FF0000", bold=True)
holiday_style.fill = PatternFill(start_color="FFF2CC", fill_type="solid")

normal_day_style = NamedStyle(name="normal_day_style")
normal_day_style.alignment = Alignment(horizontal="center", vertical="center")
normal_day_style.border = Border(left=Side(style='thin'), right=Side(style='thin'),
                                 top=Side(style='thin'), bottom=Side(style='thin'))

# 添加样式到工作簿
wb.add_named_style(header_style)
wb.add_named_style(weekend_style)
wb.add_named_style(holiday_style)
wb.add_named_style(normal_day_style)

# 为每个月创建日历
for month in range(1, 13):
    month_title = f"{month_abbr[month]}"
    ws = wb.create_sheet(title=month_title)

    # 设置月份标题
    ws.merge_cells('A1:G1')
    ws['A1'] = f"{month_title}"
    ws['A1'].style = header_style

    # 设置星期标题
    weekdays = ["一", "二", "三", "四", "五", "六", "日"]
    for col, day in enumerate(weekdays, start=1):
        cell = ws.cell(row=3, column=col, value=day)
        cell.style = header_style
        ws.column_dimensions[get_column_letter(col)].width = 12

    # 获取当月日历
    cal = monthcalendar(2025, month)

    # 填充日期
    for week_num, week in enumerate(cal, start=4):
        for day_num, day in enumerate(week, start=1):
            if day != 0:
                current_date = date(2025, month, day)
                cell = ws.cell(row=week_num, column=day_num, value=day)

                # 判断是否是周末
                if day_num in [6, 7]:  # 星期六、星期日
                    cell.style = weekend_style
                else:
                    cell.style = normal_day_style

                # 判断是否是节假日
                if current_date in cn_holidays:
                    cell.style = holiday_style
                    holiday_name = cn_holidays.get(current_date)
                    ws.cell(row=week_num, column=day_num, value=f"{day}\n{holiday_name}").alignment = Alignment(
                        horizontal="center", vertical="center", wrap_text=True)

    # 添加备注说明
    ws['A10'] = "图例说明:"
    ws['A11'] = "红色: 周末"
    ws['A11'].style = weekend_style
    ws['A12'] = "黄色: 法定节假日"
    ws['A12'].style = holiday_style



# 创建目标目录(如果不存在)
os.makedirs("../file", exist_ok=True)

# 保存文件到指定路径
filename = "../file/2025年日历.xlsx"
wb.save(filename)
print(f"2025年日历已生成,文件名: {filename}")
相关推荐
电子云与长程纠缠7 分钟前
UE5制作六边形包裹球体效果
开发语言·python·ue5
IT_陈寒13 分钟前
Vite动态导入把我坑惨了,原来要这样用才对
前端·人工智能·后端
砍材农夫13 分钟前
物联网 基于netty构建mqtt协议规范(遗嘱与保留消息)
java·开发语言·物联网·netty
DFT计算杂谈16 分钟前
KPROJ编译教程
java·前端·python·算法·conda
觅_19 分钟前
前端学习后端的时候 选择一个技术
前端·学习
独泪了无痕22 分钟前
CryptoJS:数据安全的JavaScript加密利器
前端·vue.js·node.js
重生之我是Java开发战士28 分钟前
【笔试强训】Week5:空调遥控, kotor和气球,走迷宫,主持人调度II,体操队形,二叉树的最大路径和,排序子序列,消减整数
java·算法·动态规划
发现一只大呆瓜1 小时前
一文搞懂 Vite 处理CommonJS包、按需编译逻辑及 Rollup 插件兼容规则
前端
念恒123061 小时前
Python(循环中断)
开发语言·python
Edwardwu1 小时前
写了个y-mxgraph:给 draw.io 接上了 Yjs,顺便解决了部署在 iframe 里的一堆问题
前端·typescript