Skip to content

Instantly share code, notes, and snippets.

@SegFaultAX
Created May 8, 2014 18:23
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 1 You must be signed in to fork a gist
  • Save SegFaultAX/3f2657c6c338691d812c to your computer and use it in GitHub Desktop.
Save SegFaultAX/3f2657c6c338691d812c to your computer and use it in GitHub Desktop.
def categorize(fn, coll):
"""Like group_by, but fn returns multiple keys"""
acc = {}
for e in coll:
keys = fn(e)
for key in keys:
if key not in acc:
acc[key] = []
acc[key].append(e)
return acc
def group_by(fn, l):
return categorize(lambda e: [fn(e)], l)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment