基于Python生成横向年度日历的代码实现

 更新时间:2026年01月28日 09:05:36   作者:U盘失踪了  
文章介绍了使用Python的calendar模块和openpyxl库生成Excel日历的方法,并描述了如何实现动态列宽、严格对齐和样式统一,以生成美观专业的日历,需要的朋友可以参考下

技术选型

  • calendar模块:Python 内置模块,用于获取每个月的天数和日期,不用自己计算平年闰年。
  • openpyxl:用于创建和编辑 Excel 文件,支持合并单元格、设置样式等操作,生成的文件可直接在 WPS/Excel 中打开。

核心思路

  1. 动态列宽:每个月的标题合并列数等于该月的实际天数(如 1 月 31 列、2 月 28 列),彻底解决空白单元格问题。
  2. 严格对齐:标题和日期的起始列完全一致,保证视觉上严丝合缝。
  3. 样式统一:设置统一的字体和对齐方式,让生成的日历更美观专业。
import calendar
from openpyxl import Workbook
from openpyxl.styles import Alignment, Font
from openpyxl.utils import get_column_letter

def generate_aligned_calendar(target_year):
    """
    生成标题与日期严格对齐的横向年度日历
    核心修复:每个月标题合并的列数 = 该月实际天数,无空白单元格
    """
    wb = Workbook()
    ws = wb.active
    ws.title = f"{target_year}年日历"

    # 定义样式
    title_font = Font(bold=True, size=12)
    title_align = Alignment(horizontal='center', vertical='center')
    date_align = Alignment(horizontal='right', vertical='center')

    current_col = 1  # 记录当前起始列,动态累加

    for month in range(1, 13):
        # 获取当前月份的实际天数(关键:用实际天数代替固定31)
        days_in_month = calendar.monthrange(target_year, month)[1]
        end_col = current_col + days_in_month - 1

        # 1. 写入并合并月份标题(合并列数 = 该月天数)
        month_title = f"{month}月"
        ws.merge_cells(start_row=1, start_column=current_col,
                       end_row=1, end_column=end_col)
        title_cell = ws.cell(row=1, column=current_col, value=month_title)
        title_cell.font = title_font
        title_cell.alignment = title_align

        # 2. 写入日期(从当前列开始,连续写入1-月末)
        for day in range(1, days_in_month + 1):
            date_cell = ws.cell(row=2, column=current_col + day - 1, value=day)
            date_cell.alignment = date_align

        # 更新下一个月的起始列
        current_col = end_col + 1

    # 统一调整列宽
    for col in range(1, current_col):
        ws.column_dimensions[get_column_letter(col)].width = 2.5

    # 保存文件
    file_name = f"{target_year}年对齐版日历.xlsx"
    wb.save(file_name)
    print(f"✅ {target_year}年日历生成成功!文件:{file_name}")
    print(f"📌 修复效果:标题与日期严格对齐,无空白单元格")

# 调用示例:生成2026年日历
if __name__ == "__main__":
    generate_aligned_calendar(2026)

效果图

需求角色人员工时1月
12345678910111213141516171819202122232425262728293031
登录功能项目经理小强0
产品经理小明11
开发小龙11
测试小王0.30.3
注册功能项目经理小强0
产品经理小明0
开发小龙0
测试小王0
注销功能项目经理小强0
产品经理小明0
开发小龙0
测试小王0

到此这篇关于基于Python生成横向年度日历的代码实现的文章就介绍到这了,更多相关Python生成横向年度日历内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • openCV显著性检测的使用

    openCV显著性检测的使用

    显著性检测就是使用图像处理技术和计算机视觉算法来定位图片中最“显著”的区域,本文主要介绍了openCV显著性检测的使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • python sklearn常用分类算法模型的调用

    python sklearn常用分类算法模型的调用

    这篇文章主要介绍了python sklearn常用分类算法模型的调用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • 记一次python 爬虫爬取深圳租房信息的过程及遇到的问题

    记一次python 爬虫爬取深圳租房信息的过程及遇到的问题

    这篇文章主要介绍了记一次python 爬虫爬取深圳租房信息的过程,帮助大家更好的理解和学习python爬虫,感兴趣的朋友可以了解下
    2020-11-11
  • Python数据读写之Python读写CSV文件

    Python数据读写之Python读写CSV文件

    这篇文章主要介绍了Python数据读写之Python读写CSV文件,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感兴趣的小伙伴可以参考一下
    2022-06-06
  • Python字典深度比较之如何高效寻找两个字典的相同点

    Python字典深度比较之如何高效寻找两个字典的相同点

    在数据密集型应用中,​​字典数据对比​​是实现数据同步、变更检测和一致性验证的核心技术,本文将全面解析Python中两个字典相同点查找的实现方法,需要的小伙伴可以了解下
    2025-08-08
  • pycharm配置Anaconda虚拟环境全过程

    pycharm配置Anaconda虚拟环境全过程

    这篇文章主要介绍了pycharm配置Anaconda虚拟环境全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • python中语法糖的妙用分享

    python中语法糖的妙用分享

    在Python中,语法糖是指一些为了增加代码的可读性、易用性和简洁性而添加的特性,本文为大家整理了一些python中常见语法糖的使用,需要的小伙伴可以了解下
    2023-11-11
  • Pandas GroupBy对象 索引与迭代方法

    Pandas GroupBy对象 索引与迭代方法

    今天小编就为大家分享一篇Pandas GroupBy对象 索引与迭代方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-11-11
  • Python 异常的捕获、异常的传递与主动抛出异常操作示例

    Python 异常的捕获、异常的传递与主动抛出异常操作示例

    这篇文章主要介绍了Python 异常的捕获、异常的传递与主动抛出异常操作,结合实例形式详细分析了Python针对异常捕获、传递、处理等常见操作技巧,需要的朋友可以参考下
    2019-09-09
  • Python3.x爬虫下载网页图片的实例讲解

    Python3.x爬虫下载网页图片的实例讲解

    今天小编就为大家分享一篇Python3.x爬虫下载网页图片的实例讲解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-05-05

最新评论