page contents

利用Python脚本实现ics文件转换csv格式!

首先说一下ICSviewer方式和网页工具转换方式的缺点。日历正文如果文字较多,ICSviewer会弄丢内容。网页工具一是会造成隐私泄露,二是毕竟受制于人。用Python脚本可以完美规避这些问题。

attachments-2025-03-zrR3TZlS67dcbf80450f0.jpg首先说一下ICSviewer方式和网页工具转换方式的缺点。日历正文如果文字较多,ICSviewer会弄丢内容。网页工具一是会造成隐私泄露,二是毕竟受制于人。用Python脚本可以完美规避这些问题。

下面说一下具体步骤。第一步当然是安装Python环境,官网下载即可。

第二步是安装必要的库,我是把ics和icalendar都装上了:

pip install ics

pip install icalendar第三步是新建一个Python脚本并运行

import csvfrom icalendar import Calendar

def ics_to_csv(input_file: str, output_file: str):  # 合法参数名    # 读取ICS文件    with open(input_file, 'rb') as f:  # 使用 input_file 参数        cal = Calendar.from_ical(f.read())

    # 创建CSV文件    with open(output_file, 'w', newline='', encoding='utf-8') as csvfile:  # 使用 output_file 参数        csv_writer = csv.writer(csvfile)        csv_writer.writerow(['Summary', 'Start Date', 'End Date', 'Description'])

        # 遍历事件        for component in cal.walk():            if component.name == "VEVENT":                summary = component.get('summary', '')                dtstart = component.get('dtstart')                start = dtstart.dt.strftime('%Y-%m-%d %H:%M:%S') if dtstart else ''                dtend = component.get('dtend')                end = dtend.dt.strftime('%Y-%m-%d %H:%M:%S') if dtend else ''                description = component.get('description', '')                csv_writer.writerow([summary, start, end, description])

# 调用函数(路径用原始字符串)ics_to_csv(r"C:\你的路径\XXXX.ics", r"C:\你的路径\XXXX.csv") 

需要注意的是路径不要设在C盘根目录,否则会权限不足。

更多相关技术内容咨询欢迎前往并持续关注好学星城论坛了解详情。

想高效系统的学习Python编程语言,推荐大家关注一个微信公众号:Python编程学习圈。每天分享行业资讯、技术干货供大家阅读,关注即可免费领取整套Python入门到进阶的学习资料以及教程,感兴趣的小伙伴赶紧行动起来吧。

attachments-2022-05-rLS4AIF8628ee5f3b7e12.jpg

  • 发表于 2025-03-21 09:23
  • 阅读 ( 31 )
  • 分类:Python开发

你可能感兴趣的文章

相关问题

0 条评论

请先 登录 后评论
小柒
小柒

1924 篇文章

作家榜 »

  1. 轩辕小不懂 2403 文章
  2. 小柒 1924 文章
  3. Pack 1135 文章
  4. Nen 576 文章
  5. 王昭君 209 文章
  6. 文双 71 文章
  7. 小威 64 文章
  8. Cara 36 文章