Unexpected side-effects of assigning to sys.modules[__name__]

Jean-Michel Pichavant jeanmichel at sequans.com
Thu Aug 6 14:01:42 EDT 2009


Steven D'Aprano wrote:
> Given this module:
>
> #funny.py
> import sys
> print "Before:"
> print "  __name__ =", __name__
> print "  sys.modules[__name__] =", sys.modules[__name__]
> sys.modules[__name__] = 123
> print "After:"
> print "  __name__ =", __name__
> print "  sys =", sys
>
>
> when I run it I get these results:
>
>
> [steve at sylar python]$ python2.6 funny.py
> Before:
>   __name__ = __main__
>   sys.modules[__name__] = <module '__main__' from 'funny.py'>
> After:
>   __name__ = None
>   sys = None
>
>
>
> I'm completely perplexed by this behaviour. sys.modules() seems to be a 
> regular dict, at least according to type(), and yet assigning to an item 
> of it seems to have unexpected, and rather weird, side-effects.
>
> What am I missing?
>
>
>
>   
Maybe when you assign 123 to sys.modules[__name__], you've removed the 
last reference on <module '__main__' from 'funny.py'> and it is 
garbaged. You are then loosing all your initial namespace.


try this one:
#funny.py
import sys
print "Before:"
print "  __name__ =", __name__
print "  sys.modules[__name__] =", sys.modules[__name__]
foo = sys.modules[__name__] # backup ref for the garbage collector
sys.modules[__name__] = 123
print "After:"
print "  __name__ =", __name__
print "  sys =", sys

Jean-Michel





More information about the Python-list mailing list