使用python读取EXCEL放假日历并制作订阅文件

前言

        不想升级IOS,苦于找不到新的日历订阅url,小菜鸡百度来百度去发现ics这东西可以自己做一个,惊喜于看到了这篇文章--使用python获取日历信息并制作订阅文件_https: //github.com/lk-itween/calendar-CSDN博客

感谢作者大大。就想自己写一个,但是发现到网上去找日历也挺麻烦,然后就参照写了一个比较简单的,通过读取EXCEL节假日信息来生成ics,目前已亲测成功。

准备工作

        制作一个EXCEL,记录节假日、补班和日期,内容设置纯文本格式

日历订阅文件生成

解析excel,拼接ics,生成文件,源码贴图如下。多个sheet根据sheet名生成多种日历。

#!/usr/bin/python
from datetime import datetime
import xlrdnow = datetime.now().strftime('%Y%m%dT%H:%M:%S')
# name 日历名称
def set_ics_header(name):return "BEGIN:VCALENDAR\n" \+ "PRODID:NULL\n" \+ "VERSION:2.0\n" \+ "CALSCALE:GREGORIAN\n" \+ "METHOD:PUBLISH\n" \+ f"X-WR-CALNAME:{name}\n" \+ "X-WR-TIMEZONE:Asia/Shanghai\n" \+ f"X-WR-CALDESC:{name}\n" \+ "BEGIN:VTIMEZONE\n" \+ "TZID:Asia/Shanghai\n" \+ "X-LIC-LOCATION:Asia/Shanghai\n" \+ "BEGIN:STANDARD\n" \+ "TZOFFSETFROM:+0800\n" \+ "TZOFFSETTO:+0800\n" \+ "TZNAME:CST\n" \+ "DTSTART:19700101T000000\n" \+ "END:STANDARD\n" \+ "END:VTIMEZONE\n"def set_jr_ics(jr, date, uid):  # jr: 节日,date:日期,uid:编序return "BEGIN:VEVENT\n" \+ f"DTSTART;VALUE=DATE:{date}\n" \+ f"DTEND;VALUE=DATE:{date}\n" \+ f"DTSTAMP:{date}T000001\n" \+ f"UID:{date}T{uid:0>6}_jr\n" \+ f"CREATED:{date}T000001\n" \+ f"DESCRIPTION:{jr}\n" \+ f"LAST-MODIFIED:{now}\n" \+ "SEQUENCE:0\n" \+ "STATUS:CONFIRMED\n" \+ f"SUMMARY:{jr}\n" \+ "TRANSP:TRANSPARENT\n" \+ "END:VEVENT\n"def concat_ics(year, jjr_list,rq_list):  # 返回一个完整的ics文件内容header = set_ics_header(year)# 将节日进行编号,生成list转成字符串jr_ics=''.join(list(map(set_jr_ics, jjr_list, rq_list,list(range(len(jjr_list))))))return header + jr_ics + 'END:VCALENDAR'# 保存文件
def save_ics(fname, text):with open(fname, 'w', encoding='utf-8') as f:f.write(text)#获取excel内容和sheet
def get_xlsfile(path):readfile=xlrd.open_workbook(path)num = readfile.nsheetsreturn readfile,numdef parse_jjr(table):name=table.namejjr=list(table.col_values(0))rq=list(map(dataformat,table.col_values(1)))return name,jjr,rqdef dataformat(date):return datetime.strptime(date, '%Y/%m/%d').strftime('%Y%m%d')if __name__ == '__main__':readfile,num = get_xlsfile('F:/ICS/calendar.xls')for i in range(num):name,jjr_list,rq_list=parse_jjr(readfile.sheets()[i])jr_ics = concat_ics(name,jjr_list,rq_list)filename = f'calendar_{name}.ics'save_ics(filename, jr_ics)

订阅日历信息

        参照原文大大,把代码和ics文件上传到gitee仓库:

源码:https://gitee.com/szjungle/calendar/blob/main/calendar.py

ics:https://gitee.com/szjungle/calendar/raw/main/calendar_2024year.ics

        直接到日历里添加日历订阅总是验证失败,可以换个方式,用safari打开地址,右上角“添加全部”可以添加到日历中,就成功啦!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/236441.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

服务器数据恢复-昆腾存储StorNext文件系统下raid5数据恢复案例

服务器数据恢复环境: 昆腾某型号存储,StorNext文件存储系统。 共有9个分别配置了24块磁盘的磁盘柜,其中8个磁盘柜存放普通数据,1个磁盘柜存放元数据。 存放元数据的磁盘柜中的24块磁盘组建了8组RAID1阵列和1组4盘RAID10阵列&#…

NCV8460ADR2G在汽车和工业应用中高压侧驱动如何破?

NCV8460ADR2G是一款完全保护的高压侧驱动器,可用于开关各种负载,如灯泡、电磁阀和其他致动器。该器件可以通过有源电流限制和高温关断针对过载情况进行内部保护。 诊断状态输出引脚提供了高温以及开关状态开路负载情况的数字故障指示。 特性:…

22 Vue3中使用v-for遍历对象

概述 使用v-for遍历对象在真实的开发中比较少见,了解即可。 对象我更喜欢统一称之为字典,假如你哪天发现我在某个前端的教程中把对象叫做字典,请你知道这两个是同一个玩意儿。 所谓字典,就是一种key-value类型的结构的统称。 …

队列(C语言版)

一.队列的概念及结构 队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有 先进先出 FIFO(First In First Out) 入队列:进行插入操作的一端称为 队尾 出队列:进行删除操作的一端称为…

网络安全之Linux环境配置及Linux基础知识讲解<三>

目录 一.下载安装Vmware二.下载安装Kali三.Linux目录结构四.Linux文件属性五.文件目录管理六.vim编辑器 一.下载安装Vmware Vmware官网:https://www.vmware.com 二.下载安装Kali Kali包含数百种工具,可用于各种信息安全任务,例如渗透测试、…

vue导出element表格,xlsx和xlsx-style生成xlsx文件并修改样式

1.下载依赖 npm install xlsx --save npm install file-saver --save npm install xlsx-style --save2.先修改xlsx-style的源码,一旦引入xlsx-style则会报错 xlsx-style使用中常见问题及解决办法: xlsx-style使用中常见问题及解决办法-CSDN博客 在\n…

SpringBoot 多环境开发配置文件

在开发过程中,往往开发环境和生产环境需要不同的配置。为了兼容两种运行环境,提高开发效率,可以使用多环境开发配置文件。 配置文件结构大概是这样: application.yml -主启动配置文件(用于控制使用哪种环境配…

Java:获取当前线程的线程组

代码示例: package com.thb;public class Demo4 {public static void main(String[] args) {ThreadGroup threadGroup Thread.currentThread().getThreadGroup();System.out.println(threadGroup.getName());} }运行输出:

“2024山西智博会”由中国人工智能学会和省科学技术协会联合主办

近日,山西省政府新闻办近日举行了“山西加快转型发展”系列主题新闻发布会的第六场发布会,同时也是“推动数字经济发展壮大”专场发布会。在发布会上,省委、省政府强调了数字经济的重要性,并将其作为重组要素资源、重塑经济结构、…

【无标题】欢迎使用Markdown编辑器

这里写自定义目录标题 欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants 创建一个自定义列表如何创建一个…

第五节TypeScript 运算符

一、描述 运算符用于执行程序代码运算。 二、运算符主要包括: 算术运算符逻辑运算符关系运算符按位运算符赋值运算符三元/条件运算符字符串运算符类型运算符 1、算术运算符 y5,对下面算术运算符进行解释: 运算符 描述 例子 x 运算结果…

ros2 humble安装joint_state_publisher功能包

第一步从GitHub下载此功能包:命令 git clone -b ros2 https://github.com/ros/joint_state_publisher.git 然后执行里面的setup.py文件就完成安装;命令是 sudo python setup.py install 最后检查是不是有安装好,输入命令: ro…

多表插入、删除操作(批量)——后端

多表插入 场景:当添加一个菜品时,还需要记录菜品的口味信息,因此需要对菜品表(dish)和口味表(dish_flavor)同时进行插入操作。 两个表的字段: 代码思路:由DishControll…

PSP - 结构生物学中的机器学习 (NIPS MLSB Workshop 2023.12)

欢迎关注我的CSDN:https://spike.blog.csdn.net/ 本文地址:https://spike.blog.csdn.net/article/details/135120094 Machine Learning in Structural Biology (机器学习在结构生物学中) 网址:https://www.mlsb.io/ Workshop at the 37th Co…

重磅发布|2023年度中国可观测性现状调研报告发布

研究目的 随着数智化转型的加速推进,企业的基础架构和应用程序愈发复杂,不确定事件频发,系统变得越来越难以搭建和管理。可观测性作为一种关键技术手段,涵盖了多个技术领域,如日志管理、指标监控、智能告警、根因分析…

usb端口管理软件有哪些(usb端口管理软件)

USB端口管理软件在当今的计算机使用中扮演着越来越重要的角色。随着USB设备的普及,如U盘、移动硬盘、数码相机等,相应的管理软件也变得越来越受欢迎。 1、USB端口管理软件可以帮助用户更好地管理和控制U盘的使用。 在插入U盘时,软件可以自动…

基于CTF探讨Web漏洞的利用与防范

写在前面 Copyright © [2023] [Myon⁶]. All rights reserved. 基于自己之前在CTF中Web方向的学习,总结出与Web相关的漏洞利用方法,主要包括:密码爆破、文件上传、SQL注入、PHP伪协议、反序列化漏洞、命令执行漏洞、文件包含漏洞、Vim…

华为鸿蒙操作系统简介及系统架构分析(1)

本文部分内容参考&#xff1a; 鸿蒙系统学习笔记(一) 鸿蒙系统介绍 特此致谢。 一、简介及历史 1. 简介 鸿蒙操作系统&#xff08;HarmonyOS&#xff09;是华为公司研制的一款自主版权的操作系统。2019年8月9日&#xff0c;鸿蒙系统在华为开发者大会<HDC.2019>上正式…

一段音频怎么做二维码?扫码播放音乐怎么做?

音频二维码主要是用来将一段音乐或者其他音频文件&#xff0c;以便用户可以通过扫码的方式来播放音频文件。那么音频二维码制作分几个步骤来完成&#xff0c;肯定有很多小伙伴非常的感兴趣&#xff0c;本篇文章就来给大家分享一下在线生成二维码的制作方法&#xff0c;在电脑的…

声音.wav文件的读取与保存

声音.wav文件的读取与保存-示例代码&#xff1a; import librosa import librosa.display import numpy as np from scipy.io.wavfile import writedef split_wav():# 读取音频文件audio_data, sample_rate librosa.load(input_file, srNone) # sr不指定为None&#xff0c;就…