python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > Python生成横向年度日历

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

作者:U盘失踪了

文章介绍了使用Python的calendar模块和openpyxl库生成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生成横向年度日历内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文