我知道我一定错过了一些基本知识-只想确保我得到准确的答案。
我有以下代码。为什么CACHE_KEYS
之后load()
仍然为None,而CACHE
不是?
import bisect
import csv
DB_FILE = "GeoLiteCity-Location.csv"
# ['locId', 'country', 'region', 'city', 'postalCode', 'latitude', 'longitude', 'metroCode', 'areaCode']
CACHE = []
CACHE_KEYS = None
def load():
R = csv.reader(open(DB_FILE))
for line in R:
CACHE.append(line)
# sort by city
CACHE.sort(key=lambda x: x[3])
CACHE_KEYS = [x[3] for x in CACHE]
if __name__ == "__main__":
load()
# test
# print get_geo("Ruther Glen")
最佳答案
我认为使其成为global
会起作用。在全局范围内定义的任何要编辑的变量都应在该函数中指定为global
。您的代码仅使一个局部变量CACHE_KEYS
并正确存储信息。但是,要确保将其复制到全局变量,请在函数中将变量声明为global
。您在append
上调用CACHE
函数,因此可以正常工作。更改后的代码。
import bisect
import csv
DB_FILE = "GeoLiteCity-Location.csv"
# ['locId', 'country', 'region', 'city', 'postalCode', 'latitude', 'longitude', 'metroCode', 'areaCode']
CACHE = []
CACHE_KEYS = None
def load():
R = csv.reader(open(DB_FILE))
for line in R:
CACHE.append(line)
# sort by city
CACHE.sort(key=lambda x: x[3])
global CACHE_KEYS
CACHE_KEYS = [x[3] for x in CACHE]
if __name__ == "__main__":
load()
每当您为全局变量分配值时,都必须将其声明为
global
。请参见以下代码段。listOne = []
def load():
listOne+=[2]
if __name__=="__main__":
load()
上面的代码有一个分配,而不是一个
append
调用。这给出了以下错误。UnboundLocalError: local variable 'listOne' referenced before assignment
但是,执行以下代码段。
listOne = []
def load():
listOne.append(2)
if __name__=="__main__":
load()
给出以下输出。
>>> print listOne
[2]
关于python - python中函数调用之间的全局变量值丢失,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/16216775/