Skip to main content

Fix slightly broken iCalendar files

Project description

ics-fixer

This program will fix common issues with ICS files that prevent programs such as Mozilla Thunderbird from parsing them.

Usage: ics-fixer [OPTIONS] INPUT_FILE [OUTPUT_FILE]

Arguments:
  INPUT_FILE     Path to the input ICS file.  [required]
  [OUTPUT_FILE]  Path for the output file. If omitted, the input file is
                 overwritten.

Options:
  --skip-mojibake-fix             Do not run the mojibake (garbled text)
                                  fixer.
  --debug                         Enable debug logging.
  --help                          Show this message and exit.

Installation

uv is recommended to install the package in a managed environment:

uv tool install ics-fixer

Dependencies

  • Python >= 3.13
  • dateparser
  • ftfy
  • icalendar
  • typer

Notes

These fields may contain desired data but will be discarded if it is incorrectly formatted:

  • Event orgainizer
  • Event attendee list

In my use case, this is acceptable as I have only encountered ICS files where malformed ORGANIZER or ATTENDEE values were useless.

If start or end time is in the wrong format and can't be parsed, the current time at the program's execution will be substituted.

If the start and end time are equal and contain the time, the end time will be shifted one hour, as some programs do not work properly with 0-length events. If the intention is an all-day event, the end time should be 24 hours after the start time.

Potential Implementations

  • Unit tests
  • Support for older Python versions
  • Timezone shifter for source files with incorrect times
  • Better fixes for malformed ORGANIZER or ATTENDEE
    • I would need real world sample data

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ics_fixer-1.0.2.tar.gz (5.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ics_fixer-1.0.2-py3-none-any.whl (6.4 kB view details)

Uploaded Python 3

File details

Details for the file ics_fixer-1.0.2.tar.gz.

File metadata

  • Download URL: ics_fixer-1.0.2.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.15

File hashes

Hashes for ics_fixer-1.0.2.tar.gz
Algorithm Hash digest
SHA256 8d419dcce5359f5c4d0b1591974ca139b7b5e939aac2651a5d3bc70c03da4bae
MD5 a642f23606f16e9724c6be99f60e2f98
BLAKE2b-256 2ea981337bc4297d4e818cf2d2235baade0b247b62d642b5f8dcea167e7acf53

See more details on using hashes here.

File details

Details for the file ics_fixer-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: ics_fixer-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 6.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.15

File hashes

Hashes for ics_fixer-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 3f30448f01ed9dee4f0376ebb6966ed9e9caa23a6a1e375db2ff14dc3cf33ddb
MD5 6ad1a23a8e233c42615f3a994835f04c
BLAKE2b-256 b597e46717db56dd8aeaeb5d58493125a4d339d6af8926253927fe6b1b956171

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page