What if replacing items in a dictionary returns the new dictionary?
data:image/s3,"s3://crabby-images/89e59/89e591553d77bd8b37fab70fa632d2b6dfa999a4" alt=""
It would be convenient if replacing items in a dictionary returns the new dictionary, in a manner analogous to str.replace(). What do you think? :: # Current behavior x = {'key1': 1} x.update(key1=3) == None x == {'key1': 3} # Original variable has changed # Possible behavior x = {'key1': 1} x.replace(key1=3) == {'key1': 3} x == {'key1': 1} # Original variable is unchanged
data:image/s3,"s3://crabby-images/22d89/22d89c5ecab2a98313d3033bdfc2cc2777a2e265" alt=""
Hi! Seems like a question for python-ideas mailing list, not for python-dev. On Fri, Apr 29, 2011 at 10:27:46AM -0400, Roy Hyunjin Han wrote:
You can implement this in your own subclass of dict, no? Oleg. -- Oleg Broytman http://phdru.name/ phd@phdru.name Programmers don't die, they just GOSUB without RETURN.
data:image/s3,"s3://crabby-images/89e59/89e591553d77bd8b37fab70fa632d2b6dfa999a4" alt=""
You can implement this in your own subclass of dict, no?
Yes, I just thought it would be convenient to have in the language itself, but the responses to my post seem to indicate that [not returning the updated object] is an intended language feature for mutable types like dict or list. class ReplaceableDict(dict): def replace(self, **kw): 'Works for replacing string-based keys' return dict(self.items() + kw.items())
data:image/s3,"s3://crabby-images/0c35f/0c35f93644e9835fd6bcf1387a9ddf763153a821" alt=""
On Fri, Apr 29, 2011 at 4:05 PM, Roy Hyunjin Han <starsareblueandfaraway@gmail.com> wrote:
In general nothing stops you to use a proxy object that returns itself after each method call, something like class using(object): def __init__(self, obj): self._wrappee = obj def unwrap(self): return self._wrappee def __getattr__(self, attr): def wrapper(*args, **kwargs): getattr(self._wrappee, attr)(*args, **kwargs) return self return wrapper d = dict() print using(d).update(dict(a=1)).update(dict(b=2)).unwrap() # prints {'a': 1, 'b': 2} l = list() print using(l).append(1).append(2).unwrap() # prints [1, 2]
data:image/s3,"s3://crabby-images/9feec/9feec9ccf6e52c7906cac8f7d082e9df9f5677ac" alt=""
On Fri, 29 Apr 2011 10:27:46 -0400, Roy Hyunjin Han <starsareblueandfaraway@gmail.com> wrote:
This belongs on python-ideas, but the short answer is no. The general language design principle (as I understand it) is that mutable object do not return themselves upon mutation, while immutable objects do return the new object. -- R. David Murray http://www.bitdance.com
data:image/s3,"s3://crabby-images/22d89/22d89c5ecab2a98313d3033bdfc2cc2777a2e265" alt=""
Hi! Seems like a question for python-ideas mailing list, not for python-dev. On Fri, Apr 29, 2011 at 10:27:46AM -0400, Roy Hyunjin Han wrote:
You can implement this in your own subclass of dict, no? Oleg. -- Oleg Broytman http://phdru.name/ phd@phdru.name Programmers don't die, they just GOSUB without RETURN.
data:image/s3,"s3://crabby-images/89e59/89e591553d77bd8b37fab70fa632d2b6dfa999a4" alt=""
You can implement this in your own subclass of dict, no?
Yes, I just thought it would be convenient to have in the language itself, but the responses to my post seem to indicate that [not returning the updated object] is an intended language feature for mutable types like dict or list. class ReplaceableDict(dict): def replace(self, **kw): 'Works for replacing string-based keys' return dict(self.items() + kw.items())
data:image/s3,"s3://crabby-images/0c35f/0c35f93644e9835fd6bcf1387a9ddf763153a821" alt=""
On Fri, Apr 29, 2011 at 4:05 PM, Roy Hyunjin Han <starsareblueandfaraway@gmail.com> wrote:
In general nothing stops you to use a proxy object that returns itself after each method call, something like class using(object): def __init__(self, obj): self._wrappee = obj def unwrap(self): return self._wrappee def __getattr__(self, attr): def wrapper(*args, **kwargs): getattr(self._wrappee, attr)(*args, **kwargs) return self return wrapper d = dict() print using(d).update(dict(a=1)).update(dict(b=2)).unwrap() # prints {'a': 1, 'b': 2} l = list() print using(l).append(1).append(2).unwrap() # prints [1, 2]
data:image/s3,"s3://crabby-images/9feec/9feec9ccf6e52c7906cac8f7d082e9df9f5677ac" alt=""
On Fri, 29 Apr 2011 10:27:46 -0400, Roy Hyunjin Han <starsareblueandfaraway@gmail.com> wrote:
This belongs on python-ideas, but the short answer is no. The general language design principle (as I understand it) is that mutable object do not return themselves upon mutation, while immutable objects do return the new object. -- R. David Murray http://www.bitdance.com
participants (5)
-
Giuseppe Ottaviano
-
Mark Shannon
-
Oleg Broytman
-
R. David Murray
-
Roy Hyunjin Han