Python之關(guān)于類變量的兩種賦值區(qū)別詳解
我就廢話不多說了,還是直接看代碼吧!
# -*- coding:utf-8 -*- #面試題,寫一個(gè)方法,將一行字符串中所有的單詞數(shù)量統(tǒng)計(jì)出來 class Person(object): TAG = "hello" p1 = Person() p2 = Person() print p1.TAG #第一種賦值方式 print p2.TAG print Person.TAG #第二種賦值方式 p1.TAG = "damn it" print p1.TAG print p2.TAG print Person.TAG
輸出結(jié)果:可以看到,只有p1的TAG,被賦值成了新的"damn it"
hello hello hello damn it hello hello
如何將所有對(duì)象引用的類變量都賦值成同一個(gè)值呢?
Person.TAG = "damn it"
輸出結(jié)果:完美解決問題
hello hello hello damn it damn it damn it
補(bǔ)充知識(shí):python類,賦值,命名空間
python中的類相當(dāng)于一個(gè)命名空間,object.attr 就是一個(gè)向上爬屬性的過程
屬性:__dict__ , __class__ , __bases__
__dict__: 實(shí)例或類或模塊的屬性 , __class__ 實(shí)例對(duì)應(yīng)的類對(duì)象,__bases__(元組):父類/超類
爬屬性:
def findAttr(obj , attr): if attr in obj.__dict__: return obj.__dict__[attr] cls = obj.__class__ if attr in cls.__dict__: return cls.__dict__[attr] for super_cls in cls.__bases__: if attr in super_cls.__dict__: return super_cls.__dict__[attr] return None
爬類:
def classTree(cls,indent):
print('.'*indent + cls.__name__)
for super_cls in cls.__bases__:
classTree(super_cls,indent+4)
賦值方式:
class Test: static_var = 1 #類屬性相當(dāng)與C++靜態(tài)成員變量 def assign(self): self.x = 1 #對(duì)象屬性賦值 t = Test() t.x = 2 #也可以這樣 ,直接賦值 t.__dict__['x'] = 3 #也可以這樣 , __dict__是對(duì)象空間詞典,每個(gè)對(duì)象一份,類對(duì)象/模塊也有 Test.add_static_var = 5 #也可以樣新增一個(gè)類屬性
類方法調(diào)用 , 常用的方式object.method() ,在python中擴(kuò)展 Class.method(object) ,兩者相同
Test.assign(t)
print(t.x)
當(dāng)object.method() 時(shí),object被傳入method(self)中的第一個(gè)參數(shù).Class.method(object) 需要手動(dòng)傳入
命名空間:
x = 0 def print_global(): print(x) #打印全局 def print_local(): x = 1 print(x) #本地變量 class A: x = 2 #類屬性==C++靜態(tài)成員變量 , print A.x def m(self): x = 3 #本地變量 self.x = 4 #對(duì)象屬性
def change_global(): global x #修改全局變量,否則x = 100 ,是增加一個(gè)本地變量 x = 100 def print_enclosing(): x = 200 def nested(): print(x) #在閉包中引用本地變量 def change_in_enclosing(): x = 1 def nested(): nonlocal x x = 2 #在閉包中改變本地變量, 如沒有nonlocal x , 在又新增一個(gè)本地變量
以上這篇Python之關(guān)于類變量的兩種賦值區(qū)別詳解別就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
教你使用Python寫一個(gè)簡(jiǎn)單的JSONParser
這篇文章主要介紹了教你使用Python寫一個(gè)簡(jiǎn)單的JSONParser,它的整個(gè)效果,有點(diǎn)類似于 python 標(biāo)準(zhǔn)庫(kù) json 的 json.load() 方法,需要的朋友可以參考下2023-04-04
Python讀取CSV文件并進(jìn)行數(shù)據(jù)可視化
這篇文章主要為大家詳細(xì)介紹了Python如何讀取CSV文件并進(jìn)行數(shù)據(jù)可視化,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-12-12
python函數(shù)和python匿名函數(shù)lambda詳解
這篇文章主要介紹了python函數(shù)和python匿名函數(shù)lambda,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09
Pytorch之nn.Upsample()和nn.ConvTranspose2d()用法詳解
nn.Upsample和nn.ConvTranspose2d是PyTorch中用于上采樣的兩種主要方法,nn.Upsample通過不同的插值方法(如nearest、bilinear)執(zhí)行上采樣,沒有可學(xué)習(xí)的參數(shù),適合快速簡(jiǎn)單的尺寸增加,而nn.ConvTranspose2d通過可學(xué)習(xí)的轉(zhuǎn)置卷積核進(jìn)行上采樣2024-10-10
Python實(shí)現(xiàn)比較兩個(gè)列表(list)范圍
這篇文章主要介紹了Python實(shí)現(xiàn)比較兩個(gè)列表(list)范圍,本文根據(jù)一道題目實(shí)現(xiàn)解決代碼,本文分別給出題目和解答源碼,需要的朋友可以參考下2015-06-06
全面解析Python的While循環(huán)語句的使用方法
這篇文章主要介紹了全面解析Python的While循環(huán)語句的使用方法,是Python入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-10-10

