Станислав обнови решението на 19.04.2012 11:14 (преди над 12 години)
+class BiDict(dict):
+ def __init__(self, *args, **kwargs):
+ self.update(*args, **kwargs)
+
+ def __setitem__(self, key, value):
+ if value.__hash__:
+ if value not in self.values():
+ super(BiDict, self).__setitem__(key, value)
+ elif value in self.values() and key in self.keys():
+ self.delete_diplicate(value)
+ super(BiDict, self).__setitem__(key, value)
+ else:
+ raise TypeError("Data duplication!")
+ else:
+ raise TypeError("unhashable type: {0}".format(type(value)))
+
+ def delete_diplicate(self, value):
+ for key in self:
+ if self[key] == value:
+ del self[key]
+ break
+
+ def update(self, *args, **kwargs):
+ if args:
+ if len(args) > 1:
+ raise TypeError("update expected at most 1 arguments, got {0}" .format(len(args)))
+ other = dict(args[0])
+ for key in other:
+ if other[key] in self.values():
+ self.delete_diplicate(other[key])
+ self[key] = other[key]
+ for key in kwargs:
+ self[key] = kwargs[key]
+
+ def setdefault(self, key, value=None):
+ if key not in self:
+ self.__setitem__(key, value)
+ return self[key]
+
+ def inverse(self):
+ inverted_dict = {value: key for key, value in self.items()}
+ self.clear()
+ self.update(inverted_dict)
+