Python范围规则究竟是什么?
如果我有一些代码:
code1
class Foo:
code2
def spam.....
code3
for code4..:
code5
x()
Run Code Online (Sandbox Code Playgroud)
在哪里x找到?一些可能的选择包括以下列表:
在执行期间,当函数spam在其他地方传递时,也存在上下文.也许lambda函数的传递方式有点不同?
某处必须有简单的参考或算法.对于中级Python程序员来说,这是一个令人困惑的世界.
以下代码在Python 2.5和3.0中按预期工作:
a, b, c = (1, 2, 3)
print(a, b, c)
def test():
print(a)
print(b)
print(c) # (A)
#c+=1 # (B)
test()
Run Code Online (Sandbox Code Playgroud)
但是,当我取消注释行(B)时,我得到了UnboundLocalError: 'c' not assigned一行(A).的值a和b被正确地打印.这让我感到困惑,原因有两个:
为什么在行(A)处抛出运行时错误,因为后面的行(B)语句?
为什么变量a和b打印符合预期,同时c引发错误?
我能想到的唯一解释是,赋值创建了一个局部变量,即使在创建局部变量之前,它也优先于"全局"变量.当然,变量在存在之前"窃取"范围是没有意义的.cc+=1c
有人可以解释一下这种行为吗?
Program A()
{
x, y, z: integer;
procedure B()
{
y: integer;
y=0;
x=z+1;
z=y+2;
}
procedure C()
{
z: integer;
procedure D()
{
x: integer;
x = z + 1;
y = x + 1;
call B();
}
z = 5;
call D();
}
x = 10;
y = 11;
z = 12;
call C();
print x, y, z;
}
Run Code Online (Sandbox Code Playgroud)
根据我的理解,使用静态作用域运行时该程序的结果是:x = 13,y = 7,z = 2.
但是,当使用动态范围运行时,结果为:x = 10,y = 7,z = 12.
这些结果是我们教授给我们的结果.但是,我无法理解他的生活如何达到这些结果.有人可能会通过伪代码并在两种不同类型的范围内解释它们的值吗?
为什么我在下面的第三个代码中出错,但在前两个中却没有?我使用的是Python 3.6.0,Anaconda 4.3.1(64位)Jupyter.
代码1:
c = 100
def fib():
c = 20
a = c
print ("a in fib", a)
print ("c in fib", c)
fib()
print ("c", c)
Run Code Online (Sandbox Code Playgroud)
代码1的输出:
a in fib 20
c in fib 20
c 100
Run Code Online (Sandbox Code Playgroud)
代码2:
c = 100
def fib():
a = c
print ("a in fib", a)
print ("c in fib", c)
fib()
print ("c", c)
Run Code Online (Sandbox Code Playgroud)
代码2的输出:
a in fib 100
c in fib 100
c 100
Run Code Online (Sandbox Code Playgroud)
代码3:
c = 100
def fib(): …Run Code Online (Sandbox Code Playgroud)