¿Hace esto lo que pretendía?
d = dict(globals())
d.update(locals())
Si leo la documentación correctamente, se crea una copia de la globals()
dict, a continuación, se sobrescribe cualquier duplicado y de inserción de nuevas entradas de la locals()
dict (ya que el locals()
deberían tener preferencia dentro de su ámbito de aplicación, de todos modos)
No he tenido ningún suerte en conseguir un funcionamiento adecuado para devolver el diccionario completo de variables en el ámbito de la llamando función. Aquí está el código (sólo se utiliza pprint para dar formato a la salida muy bien para el SO):
from pprint import *
def allvars_bad():
fake_temp_var = 1
d = dict(globals())
d.update(locals())
return d
def foo_bad():
x = 5
return allvars_bad()
def foo_good():
x = 5
fake_temp_var = "good"
d = dict(globals())
d.update(locals())
return d
pprint (foo_bad(), width=50)
pprint (foo_good(), width=50)
y la salida:
{'PrettyPrinter': <class pprint.PrettyPrinter at 0xb7d316ec>,
'__builtins__': <module '__builtin__' (built-in)>,
'__doc__': None,
'__file__': 'temp.py',
'__name__': '__main__',
'__package__': None,
'allvars_bad': <function allvars_bad at 0xb7d32b1c>,
'd': <Recursion on dict with id=3084093748>,
'fake_temp_var': 1,
'foo_bad': <function foo_bad at 0xb7d329cc>,
'foo_good': <function foo_good at 0xb7d32f0c>,
'isreadable': <function isreadable at 0xb7d32c34>,
'isrecursive': <function isrecursive at 0xb7d32c6c>,
'pformat': <function pformat at 0xb7d32bc4>,
'pprint': <function pprint at 0xb7d32b8c>,
'saferepr': <function saferepr at 0xb7d32bfc>}
{'PrettyPrinter': <class pprint.PrettyPrinter at 0xb7d316ec>,
'__builtins__': <module '__builtin__' (built-in)>,
'__doc__': None,
'__file__': 'temp.py',
'__name__': '__main__',
'__package__': None,
'allvars_bad': <function allvars_bad at 0xb7d32b1c>,
'd': <Recursion on dict with id=3084093884>,
'fake_temp_var': 'good',
'foo_bad': <function foo_bad at 0xb7d329cc>,
'foo_good': <function foo_good at 0xb7d32f0c>,
'isreadable': <function isreadable at 0xb7d32c34>,
'isrecursive': <function isrecursive at 0xb7d32c6c>,
'pformat': <function pformat at 0xb7d32bc4>,
'pprint': <function pprint at 0xb7d32b8c>,
'saferepr': <function saferepr at 0xb7d32bfc>,
'x': 5}
Nótese que en la segunda salida, hemos sobrescrito fake_temp_var
, y X es presente; la primera salida solo incluía los vars locales dentro del alcance de allvars_bad
.
Si quiere acceder al ámbito de variable completo, no puede poner los locales() dentro de otra función.
Yo sospechaba que había algún tipo de objeto de marco, simplemente no sabía dónde buscarlo.
Esto funciona a su especificación, creo:
def allvars_good(offset=0):
frame = sys._getframe(1+offset)
d = frame.f_globals
d.update(frame.f_locals)
return d
def foo_good2():
a = 1
b = 2
return allvars_good()
->
{'PrettyPrinter': <class pprint.PrettyPrinter at 0xb7d6474c>,
'__builtins__': <module '__builtin__' (built-in)>,
'__doc__': None,
'__file__': 'temp.py',
'__name__': '__main__',
'__package__': None,
'a': 1,
'allvars_bad': <function allvars_bad at 0xb7d65b54>,
'allvars_good': <function allvars_good at 0xb7d65a04>,
'b': 2,
'foo_bad': <function foo_bad at 0xb7d65f44>,
'foo_good': <function foo_good at 0xb7d65f7c>,
'foo_good2': <function foo_good2 at 0xb7d65fb4>,
'isreadable': <function isreadable at 0xb7d65c6c>,
'isrecursive': <function isrecursive at 0xb7d65ca4>,
'pformat': <function pformat at 0xb7d65bfc>,
'pprint': <function pprint at 0xb7d65bc4>,
'saferepr': <function saferepr at 0xb7d65c34>,
'sys': <module 'sys' (built-in)>}
¿Por qué querrías hacer eso? Lo más probable es que haya una mejor manera de hacer lo que sea que intentes hacer. –
Pensé que el fragmento lo dejaría en claro. Me gustaría interpolar las variables dentro de las cadenas. Por supuesto, podría haber una mejor manera. Por favor, siéntase libre de sugerir uno como respuesta. –
Lo sentimos, el fragmento no explica ** por qué ** necesita tal cosa. Además, los parámetros son simplemente locales, no es un ámbito separado. –