ical2txt.py - Updated processing to filter Google Meet and Skype Meeting details but keep the rest of the description. Discard bs4 warnings about URL's. Inserted a progress-meter (although it seems to only print when finished) and event total.
This commit is contained in:
parent
a11e9ca33f
commit
55b2edd732
19
ical2txt.py
19
ical2txt.py
@ -5,6 +5,9 @@ import os.path
|
|||||||
from icalendar import Calendar
|
from icalendar import Calendar
|
||||||
import csv
|
import csv
|
||||||
from bs4 import BeautifulSoup
|
from bs4 import BeautifulSoup
|
||||||
|
import warnings
|
||||||
|
|
||||||
|
warnings.filterwarnings("ignore", category=UserWarning, module='bs4') # We don't want warnings about URL's. We just what the URL printed, if there.
|
||||||
|
|
||||||
filename = sys.argv[1]
|
filename = sys.argv[1]
|
||||||
# TODO: use regex to get file extension (chars after last period), in case it's not exactly 3 chars.
|
# TODO: use regex to get file extension (chars after last period), in case it's not exactly 3 chars.
|
||||||
@ -85,6 +88,8 @@ def txt_write(icsfile):
|
|||||||
txtfile = icsfile[:-3] + "txt"
|
txtfile = icsfile[:-3] + "txt"
|
||||||
prevdate=""
|
prevdate=""
|
||||||
spent=0
|
spent=0
|
||||||
|
evcount=0
|
||||||
|
print("Processing events :", end=" ")
|
||||||
try:
|
try:
|
||||||
with open(txtfile, 'w') as myfile:
|
with open(txtfile, 'w') as myfile:
|
||||||
for event in sortedevents:
|
for event in sortedevents:
|
||||||
@ -104,12 +109,20 @@ def txt_write(icsfile):
|
|||||||
spent += ds
|
spent += ds
|
||||||
hours = divmod(ds, 3600)[0]
|
hours = divmod(ds, 3600)[0]
|
||||||
minutes = divmod(ds,3600)[1]/60
|
minutes = divmod(ds,3600)[1]/60
|
||||||
|
description=removehtml(event.description.encode('utf-8').decode())
|
||||||
values = event.start.strftime("%H:%M:%S") + " - " + event.end.strftime("%H:%M:%S") + " (" + '{:02.0f}'.format(hours) + ":" + '{:02.0f}'.format(minutes) + ") " + event.summary.encode('utf-8').decode()
|
values = event.start.strftime("%H:%M:%S") + " - " + event.end.strftime("%H:%M:%S") + " (" + '{:02.0f}'.format(hours) + ":" + '{:02.0f}'.format(minutes) + ") " + event.summary.encode('utf-8').decode()
|
||||||
if event.location != '': values = values + " [" + event.location + "]" # Only include location if there is one
|
if event.location != '': values = values + " [" + event.location + "]" # Only include location if there is one
|
||||||
if event.description.rfind('joining options') == -1: # Skip description if it has Google Meeting information
|
|
||||||
values = values + "\n" + removehtml(event.description.encode('utf-8').decode())
|
# Remove Google Meet and Skype Meeting part of description
|
||||||
|
trimmed=description.split('-::~')[0].split('......')[0]
|
||||||
|
#print("DescLen: " + str(len(description)) + " TrimmedLen: " + str(len(trimmed)) + " : " + trimmed) # For debugging
|
||||||
|
description=trimmed
|
||||||
|
if description != '':
|
||||||
|
values = values + "\n" + description + "\n"
|
||||||
myfile.write(values+"\n")
|
myfile.write(values+"\n")
|
||||||
print("Wrote to ", txtfile, "\n")
|
print("", end=".")
|
||||||
|
evcount+=1
|
||||||
|
print("\n\nWrote " + str(evcount) + " events to ", txtfile, "\n")
|
||||||
except IOError:
|
except IOError:
|
||||||
print("Could not open file! Please close Excel!")
|
print("Could not open file! Please close Excel!")
|
||||||
exit(0)
|
exit(0)
|
||||||
|
Loading…
Reference in New Issue
Block a user