mirror of
https://github.com/b4tman/sync_ics2gcal
synced 2025-01-21 23:38:58 +00:00
performance fix in compare
zip()'ing sorted lists is like 10x faster ( 1.56 seconds instead of 15.05 in test_compare, part_len=5000 )
This commit is contained in:
parent
8eb94089a7
commit
8ea8512c11
@ -39,19 +39,17 @@ class CalendarSync():
|
|||||||
keys_to_update = keys_src & keys_dst
|
keys_to_update = keys_src & keys_dst
|
||||||
keys_to_delete = keys_dst - keys_src
|
keys_to_delete = keys_dst - keys_src
|
||||||
|
|
||||||
def get_item(items, key_val):
|
|
||||||
for item in filter(lambda item: item[key] == key_val, items):
|
|
||||||
return item
|
|
||||||
|
|
||||||
def items_by_keys(items, key_name, keys):
|
def items_by_keys(items, key_name, keys):
|
||||||
return list(filter(lambda item: item[key_name] in keys, items))
|
return list(filter(lambda item: item[key_name] in keys, items))
|
||||||
|
|
||||||
items_to_insert = items_by_keys(items_src, key, keys_to_insert)
|
items_to_insert = items_by_keys(items_src, key, keys_to_insert)
|
||||||
items_to_delete = items_by_keys(items_dst, key, keys_to_delete)
|
items_to_delete = items_by_keys(items_dst, key, keys_to_delete)
|
||||||
|
|
||||||
items_to_update = []
|
to_upd_src = items_by_keys(items_src, key, keys_to_update)
|
||||||
for key_val in keys_to_update:
|
to_upd_dst = items_by_keys(items_dst, key, keys_to_update)
|
||||||
items_to_update.append( (get_item(items_src, key_val), get_item(items_dst, key_val)) )
|
to_upd_src.sort(key=get_key)
|
||||||
|
to_upd_dst.sort(key=get_key)
|
||||||
|
items_to_update = list(zip(to_upd_src, to_upd_dst))
|
||||||
|
|
||||||
return items_to_insert, items_to_update, items_to_delete
|
return items_to_insert, items_to_update, items_to_delete
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user