一尘不染

如何在Python中从外部获取/设置函数的局部变量?

python

如果我有一个函数(在Python 2.5.2中)像这样:

def sample_func():
    a = 78
    b = range(5)
    #c = a + b[2] - x

我的问题是:

  1. 如何在 使用函数内部的 locals()的 情况下 从外部 获取 函数的局部变量(a,b)?(反射的种类)
  2. 是否可以从外部设置局部变量(例如 x ),以便注释行起作用?(我知道这听起来很奇怪)。

提前致谢。

编辑

每个人都在寻找用例。但这是一个奇怪的情况。(不要怪我,我没有创造出来)。这是场景:

  1. 我有一个包含python函数的加密python源文件。
  2. AC扩展模块将其解密并在内存中构建该功能。
  3. 一个主要的python程序首先使用该加密文件位置调用C扩展名。
  4. 然后,主程序调用已在内存中构建的函数(通过C扩展)
  5. 但是主程序需要知道该函数的局部变量(不要问我为什么,不是我)
  6. 由于某些(该死的)原因,主程序也需要设置一个变量(最奇怪的)

阅读 235

收藏
2020-12-20

共1个答案

一尘不染

否。未运行的函数没有本地语言;这只是一个功能。询问如何在不运行时修改函数的本地变量,就像询问如何在不运行时修改程序的堆一样。

但是,如果确实需要,可以修改常量。

def func():
    a = 10
    print a

co = func.func_code
modified_consts = list(co.co_consts)
for idx, val in enumerate(modified_consts):
    if modified_consts[idx] == 10: modified_consts[idx] = 15

modified_consts = tuple(modified_consts)

import types
modified_code = types.CodeType(co.co_argcount, co.co_nlocals, co.co_stacksize, co.co_flags, co.co_code, modified_consts, co.co_names, co.co_varnames, co.co_filename, co.co_name, co.co_firstlineno, co.co_lnotab)
modified_func = types.FunctionType(modified_code, func.func_globals)
# 15:
modified_func()

这是骇客,因为无法知道co.co_consts中的哪个常量是哪个;这使用一个哨兵值来解决。根据您是否可以充分限制用例,就足够了。

2020-12-20