mirror of
https://github.com/m-lamonaca/dev-notes.git
synced 2025-04-05 18:36:41 +00:00
78 lines
2.7 KiB
Markdown
78 lines
2.7 KiB
Markdown
|
||
# Collections Module
|
||
|
||
``` py
|
||
# COUNTER ()
|
||
# subclass dictionary for counting hash-capable objects
|
||
from collections import Counter
|
||
Counter (sequence) # -> Counter object
|
||
# {item: num included in sequence, ...}
|
||
|
||
var = Counter (sequence)
|
||
var.most_common (n) # produce list of most common elements (most common n)
|
||
sum (var.values ()) # total of all counts
|
||
var.clear () #reset all counts
|
||
list (var) # list unique items
|
||
set (var) # convert to a set
|
||
dict (var) # convert to regular dictionary
|
||
var.items () # convert to a list of pairs (element, count)
|
||
Counter (dict (list_of_pairs)) # convert from a list of pairs
|
||
var.most_common [: - n-1: -1] # n less common elements
|
||
var + = Counter () # remove zero and negative counts
|
||
|
||
|
||
# DEFAULTDICT ()
|
||
# dictionary-like object that takes a default type as its first argument
|
||
# defaultdict will never raise a KeyError exception.
|
||
# non-existent keys return a default value (default_factory)
|
||
from collections import defaultdict
|
||
var = defaultdict (default_factory)
|
||
var.popitem () # remove and return first element
|
||
var.popitem (last = True) # remove and return last item
|
||
|
||
|
||
# OREDERDDICT ()
|
||
# subclass dictionary that "remembers" the order in which the contents are entered
|
||
# Normal dictionaries have random order
|
||
name_dict = OrderedDict ()
|
||
# OrderedDict with same elements but different order are considered different
|
||
|
||
|
||
# USERDICT ()
|
||
# pure implementation in pythondi a map that works like a normal dictionary.
|
||
# Designated to create subclasses
|
||
UserDict.data # recipient of UserDict content
|
||
|
||
|
||
# NAMEDTUPLE ()
|
||
# each namedtuple is represented by its own class
|
||
from collections import namedtuple
|
||
NomeClasse = namedtuple (NomeClasse, parameters_separated_from_space)
|
||
var = ClassName (parameters)
|
||
var.attribute # access to attributes
|
||
var [index] # access to attributes
|
||
var._fields # access to attribute list
|
||
var = class._make (iterable) # transformain namedtuple
|
||
var._asdict () # Return OrderedDict object starting from namedtuple
|
||
|
||
|
||
# DEQUE ()
|
||
# double ended queue (pronounced "deck")
|
||
# list editable on both "sides"
|
||
from collections import deque
|
||
var = deque (iterable, maxlen = num) # -> deque object
|
||
var.append (item) # add item to the bottom
|
||
var.appendleft (item) # add item to the beginning
|
||
var.clear () # remove all elements
|
||
var.extend (iterable) # add iterable to the bottom
|
||
var.extendleft (iterable) # add iterable to the beginning '
|
||
var.insert (index, item) # insert index position
|
||
var.index (item, start, stop) # returns position of item
|
||
var.count (item)
|
||
var.pop ()
|
||
var.popleft ()
|
||
var.remove (value)
|
||
var.reverse () # reverse element order
|
||
var.rotate (n) # move the elements of n steps (dx if n> 0, sx if n <0)
|
||
var.sort ()
|
||
```
|