为函数中的全局变量赋值时,为什么在赋值"之前引用了"错误?

2024-08-21Python开发问题
11

本文介绍了为函数中的全局变量赋值时,为什么在赋值"之前引用了"错误?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

在Python中,我收到以下错误:

UnboundLocalError: local variable 'total' referenced before assignment

在文件的开头(在错误所在的函数之前),我使用global关键字声明total。然后,在程序体中,在调用使用total的函数之前,我将其赋值为0。我已尝试在不同位置(包括声明之后的文件顶部)将其设置为0,但无法使其正常工作。

有人看到我做错了什么吗?

推荐答案

我认为您错误地使用了"GLOBAL"。请参见Python reference。您应该声明不带GLOBAL的变量,然后在函数内部,当您想要访问全局变量时,您可以声明它global yourvar

#!/usr/bin/python

total

def checkTotal():
    global total
    total = 0

请参见此示例:

#!/usr/bin/env python

total = 0

def doA():
    # not accessing global total
    total = 10

def doB():
    global total
    total = total + 1

def checkTotal():
    # global total - not required as global is required
    # only for assignment - thanks for comment Greg
    print total

def main():
    doA()
    doB()
    checkTotal()

if __name__ == '__main__':
    main()

因为doA()不修改全局合计,所以输出为%1而不是%11。

这篇关于为函数中的全局变量赋值时,为什么在赋值"之前引用了"错误?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

The End

相关推荐

在xarray中按单个维度的多个坐标分组
groupby multiple coords along a single dimension in xarray(在xarray中按单个维度的多个坐标分组)...
2024-08-22 Python开发问题
15

Pandas中的GROUP BY AND SUM不丢失列
Group by and Sum in Pandas without losing columns(Pandas中的GROUP BY AND SUM不丢失列)...
2024-08-22 Python开发问题
17

pandas 有从特定日期开始的按月分组的方式吗?
Is there a way of group by month in Pandas starting at specific day number?( pandas 有从特定日期开始的按月分组的方式吗?)...
2024-08-22 Python开发问题
10

GROUP BY+新列+基于条件的前一行抓取值
Group by + New Column + Grab value former row based on conditionals(GROUP BY+新列+基于条件的前一行抓取值)...
2024-08-22 Python开发问题
18

PANDA中的Groupby算法和插值算法
Groupby and interpolate in Pandas(PANDA中的Groupby算法和插值算法)...
2024-08-22 Python开发问题
11

PANAS-基于列对行进行分组,并将NaN替换为非空值
Pandas - Group Rows based on a column and replace NaN with non-null values(PANAS-基于列对行进行分组,并将NaN替换为非空值)...
2024-08-22 Python开发问题
10