
解讀Python編程中的命名空間與作用域
變量是擁有匹配對象的名字(標(biāo)識符)。命名空間是一個(gè)包含了變量名稱們(鍵)和它們各自相應(yīng)的對象們(值)的字典。
一個(gè)Python表達(dá)式可以訪問局部命名空間和全局命名空間里的變量。如果一個(gè)局部變量和一個(gè)全局變量重名,則局部變量會(huì)覆蓋全局變量。
每個(gè)函數(shù)都有自己的命名空間。類的方法的作用域規(guī)則和通常函數(shù)的一樣。
Python會(huì)智能地猜測一個(gè)變量是局部的還是全局的,它假設(shè)任何在函數(shù)內(nèi)賦值的變量都是局部的。
因此,如果要給全局變量在一個(gè)函數(shù)里賦值,必須使用global語句。
global VarName的表達(dá)式會(huì)告訴Python, VarName是一個(gè)全局變量,這樣Python就不會(huì)在局部命名空間里尋找這個(gè)變量了。
命名空間的定義
Python命名空間是名稱到對象的映射,這就像是字典,鍵名是變量名,值是變量的值。比如:
>>> x = 3
>>> globals()
{'__builtins__': <module '__builtin__' (built-in)>, '__name__': '__main__', '__doc__': None, 'x': 3, '__package__': None}
可以看到變量x,3以字典的形式存放在globals空間內(nèi)。以之對應(yīng)的名字空間還有:locals()。
>>> locals()
{'__builtins__': <module '__builtin__' (built-in)>, '__name__': '__main__', '__doc__': None, 'x': 3, '__package__': None}
實(shí)際上,你可以通過向名字添加鍵名和值:
>>> globals()['y'] = 5
>>> y
5
上圖左側(cè)是內(nèi)置命名空間,右側(cè)是不同的模塊,有各自的全局命名空間,全局命名空間內(nèi)定義函數(shù)就會(huì)有局部命名空間。
命名空間的種類
Python中有三種命名空間:
a) 局部,函數(shù)內(nèi)的命名空間就是局部的;
b) 全局,模塊內(nèi)的命名空間就是全局的;
c) 內(nèi)置,包括異常類型、內(nèi)建函數(shù)和特殊方法,可以代碼中任意地方調(diào)用;
下面討論關(guān)于名字空間的搜索順序,先來看張圖:
命名空間的可見性(作用域)
a) 內(nèi)置命名空間在代碼所有位置都是可見的,所以可以隨時(shí)被調(diào)用;
b) 全局命名空間和局部命名空間中, 如果有同名變量,在全局命名空間處,局部命名空間內(nèi)的同名變量是不可見的;
c) 在局部命名空間處,全局命名空間的同名變量是不可見的(只有變量不同名的情況下,可使用 global關(guān)鍵字讓其可見)。
知道了可見性,下面說變量的查找順序就要清楚多了。
命名空間的查找順序
a) 如果在函數(shù)內(nèi)調(diào)用一個(gè)變量,先在函數(shù)內(nèi)(局部命名空間)查找,如果找到則停止查找。否則在函數(shù)外部(全局命名空間)查找,如果還是沒找到,則查找內(nèi)置命名空間。如果以上三個(gè)命名都未找到,則拋出NameError 的異常錯(cuò)誤。
b)
如果在函數(shù)外調(diào)用一個(gè)變量,則在函數(shù)外查找(全局命名空間,局部命名空間此時(shí)不可見),如果找到則停止查找,否則到內(nèi)置命名空間中查找。如果兩者都找不到,則拋出異常。只有當(dāng)局部命名空間內(nèi),使用global
關(guān)鍵字聲明了一個(gè)變量時(shí),查找順序則是 a) 的查找順序。
為了幫助理解,來舉個(gè)例子,我們在全局命名空間里定義一個(gè)變量money。我們再在函數(shù)內(nèi)給變量money賦值,然后Python會(huì)假定money是一個(gè)局部變量。然而,我們并沒有在訪問前聲明一個(gè)局部變量money,結(jié)果就是會(huì)出現(xiàn)一個(gè)UnboundLocalError的錯(cuò)誤。取消global語句的注釋就能解決這個(gè)問題。
#!/usr/bin/python
# -*- coding: UTF-8 -*-
Money = 2000
def AddMoney():
# 想改正代碼就取消以下注釋:
# global Money
Money = Money + 1
print Money
AddMoney()
print Money
dir()函數(shù)
dir()函數(shù)一個(gè)排好序的字符串列表,內(nèi)容是一個(gè)模塊里定義過的名字。
返回的列表容納了在一個(gè)模塊里定義的所有模塊,變量和函數(shù)。如下一個(gè)簡單的實(shí)例:
#!/usr/bin/python
# -*- coding: UTF-8 -*-
# 導(dǎo)入內(nèi)置math模塊
import math
content = dir(math)
print content;
以上實(shí)例輸出結(jié)果:
['__doc__', '__file__', '__name__', 'acos', 'asin', 'atan',
'atan2', 'ceil', 'cos', 'cosh', 'degrees', 'e', 'exp',
'fabs', 'floor', 'fmod', 'frexp', 'hypot', 'ldexp', 'log',
'log10', 'modf', 'pi', 'pow', 'radians', 'sin', 'sinh',
'sqrt', 'tan', 'tanh']
在這里,特殊字符串變量__name__指向模塊的名字,__file__指向該模塊的導(dǎo)入文件名。
globals()和locals()函數(shù)
根據(jù)調(diào)用地方的不同,globals()和locals()函數(shù)可被用來返回全局和局部命名空間里的名字。
如果在函數(shù)內(nèi)部調(diào)用locals(),返回的是所有能在該函數(shù)里訪問的命名。
如果在函數(shù)內(nèi)部調(diào)用globals(),返回的是所有在該函數(shù)里能訪問的全局名字。
兩個(gè)函數(shù)的返回類型都是字典。所以名字們能用keys()函數(shù)摘取。
reload()函數(shù)
當(dāng)一個(gè)模塊被導(dǎo)入到一個(gè)腳本,模塊頂層部分的代碼只會(huì)被執(zhí)行一次。
因此,如果你想重新執(zhí)行模塊里頂層部分的代碼,可以用reload()函數(shù)。該函數(shù)會(huì)重新導(dǎo)入之前導(dǎo)入過的模塊。語法如下:
reload(module_name)
在這里,module_name要直接放模塊的名字,而不是一個(gè)字符串形式。比如想重載hello模塊,如下:
reload(hello)
數(shù)據(jù)分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
SQL Server 中 CONVERT 函數(shù)的日期轉(zhuǎn)換:從基礎(chǔ)用法到實(shí)戰(zhàn)優(yōu)化 在 SQL Server 的數(shù)據(jù)處理中,日期格式轉(zhuǎn)換是高頻需求 —— 無論 ...
2025-09-18MySQL 大表拆分與關(guān)聯(lián)查詢效率:打破 “拆分必慢” 的認(rèn)知誤區(qū) 在 MySQL 數(shù)據(jù)庫管理中,“大表” 始終是性能優(yōu)化繞不開的話題。 ...
2025-09-18CDA 數(shù)據(jù)分析師:表結(jié)構(gòu)數(shù)據(jù) “獲取 - 加工 - 使用” 全流程的賦能者 表結(jié)構(gòu)數(shù)據(jù)(如數(shù)據(jù)庫表、Excel 表、CSV 文件)是企業(yè)數(shù)字 ...
2025-09-18DSGE 模型中的 Et:理性預(yù)期算子的內(nèi)涵、作用與應(yīng)用解析 動(dòng)態(tài)隨機(jī)一般均衡(Dynamic Stochastic General Equilibrium, DSGE)模 ...
2025-09-17Python 提取 TIF 中地名的完整指南 一、先明確:TIF 中的地名有哪兩種存在形式? 在開始提取前,需先判斷 TIF 文件的類型 —— ...
2025-09-17CDA 數(shù)據(jù)分析師:解鎖表結(jié)構(gòu)數(shù)據(jù)特征價(jià)值的專業(yè)核心 表結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 規(guī)范存儲(chǔ)的結(jié)構(gòu)化數(shù)據(jù),如數(shù)據(jù)庫表、Excel 表、 ...
2025-09-17Excel 導(dǎo)入數(shù)據(jù)含缺失值?詳解 dropna 函數(shù)的功能與實(shí)戰(zhàn)應(yīng)用 在用 Python(如 pandas 庫)處理 Excel 數(shù)據(jù)時(shí),“缺失值” 是高頻 ...
2025-09-16深入解析卡方檢驗(yàn)與 t 檢驗(yàn):差異、適用場景與實(shí)踐應(yīng)用 在數(shù)據(jù)分析與統(tǒng)計(jì)學(xué)領(lǐng)域,假設(shè)檢驗(yàn)是驗(yàn)證研究假設(shè)、判斷數(shù)據(jù)差異是否 “ ...
2025-09-16CDA 數(shù)據(jù)分析師:掌控表格結(jié)構(gòu)數(shù)據(jù)全功能周期的專業(yè)操盤手 表格結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 存儲(chǔ)的結(jié)構(gòu)化數(shù)據(jù),如 Excel 表、數(shù)據(jù) ...
2025-09-16MySQL 執(zhí)行計(jì)劃中 rows 數(shù)量的準(zhǔn)確性解析:原理、影響因素與優(yōu)化 在 MySQL SQL 調(diào)優(yōu)中,EXPLAIN執(zhí)行計(jì)劃是核心工具,而其中的row ...
2025-09-15解析 Python 中 Response 對象的 text 與 content:區(qū)別、場景與實(shí)踐指南 在 Python 進(jìn)行 HTTP 網(wǎng)絡(luò)請求開發(fā)時(shí)(如使用requests ...
2025-09-15CDA 數(shù)據(jù)分析師:激活表格結(jié)構(gòu)數(shù)據(jù)價(jià)值的核心操盤手 表格結(jié)構(gòu)數(shù)據(jù)(如 Excel 表格、數(shù)據(jù)庫表)是企業(yè)最基礎(chǔ)、最核心的數(shù)據(jù)形態(tài) ...
2025-09-15Python HTTP 請求工具對比:urllib.request 與 requests 的核心差異與選擇指南 在 Python 處理 HTTP 請求(如接口調(diào)用、數(shù)據(jù)爬取 ...
2025-09-12解決 pd.read_csv 讀取長浮點(diǎn)數(shù)據(jù)的科學(xué)計(jì)數(shù)法問題 為幫助 Python 數(shù)據(jù)從業(yè)者解決pd.read_csv讀取長浮點(diǎn)數(shù)據(jù)時(shí)的科學(xué)計(jì)數(shù)法問題 ...
2025-09-12CDA 數(shù)據(jù)分析師:業(yè)務(wù)數(shù)據(jù)分析步驟的落地者與價(jià)值優(yōu)化者 業(yè)務(wù)數(shù)據(jù)分析是企業(yè)解決日常運(yùn)營問題、提升執(zhí)行效率的核心手段,其價(jià)值 ...
2025-09-12用 SQL 驗(yàn)證業(yè)務(wù)邏輯:從規(guī)則拆解到數(shù)據(jù)把關(guān)的實(shí)戰(zhàn)指南 在業(yè)務(wù)系統(tǒng)落地過程中,“業(yè)務(wù)邏輯” 是連接 “需求設(shè)計(jì)” 與 “用戶體驗(yàn) ...
2025-09-11塔吉特百貨孕婦營銷案例:數(shù)據(jù)驅(qū)動(dòng)下的精準(zhǔn)零售革命與啟示 在零售行業(yè) “流量紅利見頂” 的當(dāng)下,精準(zhǔn)營銷成為企業(yè)突圍的核心方 ...
2025-09-11CDA 數(shù)據(jù)分析師與戰(zhàn)略 / 業(yè)務(wù)數(shù)據(jù)分析:概念辨析與協(xié)同價(jià)值 在數(shù)據(jù)驅(qū)動(dòng)決策的體系中,“戰(zhàn)略數(shù)據(jù)分析”“業(yè)務(wù)數(shù)據(jù)分析” 是企業(yè) ...
2025-09-11Excel 數(shù)據(jù)聚類分析:從操作實(shí)踐到業(yè)務(wù)價(jià)值挖掘 在數(shù)據(jù)分析場景中,聚類分析作為 “無監(jiān)督分組” 的核心工具,能從雜亂數(shù)據(jù)中挖 ...
2025-09-10統(tǒng)計(jì)模型的核心目的:從數(shù)據(jù)解讀到?jīng)Q策支撐的價(jià)值導(dǎo)向 統(tǒng)計(jì)模型作為數(shù)據(jù)分析的核心工具,并非簡單的 “公式堆砌”,而是圍繞特定 ...
2025-09-10