
Python關于反射和類的特殊成員方法
本文給大家分享python關于反射和類的特殊成員方法,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
反射即想到4個內置函數(shù)分別為:getattr、hasattr、setattr、delattr 獲取成員、檢查成員、設置成員、刪除成員
class Dog(object):
def __init__(self,name):
self.name = name
def eat(self):
print("%s is eating..."%self.name)
def run():
print("runing ....")
d = Dog("lucy")
choise=input("請輸入要調用的方法:")
if hasattr(d,choise):#判斷一個對象是否有對應的字符串方法
func=getattr(d,choise)#根據(jù)字符串去獲取對象里相應的方法或屬性的內存地址對象
func()
else:
setattr(d,choise,run)#setattr(obj,y,fun)相當于obj.y=fun,fun可以是屬性或者方法
v=getattr(d,choise)
print(v)
dir([obj]):
調用這個方法將返回包含obj大多數(shù)屬性名的列表(會有一些特殊的屬性不包含在內)。obj的默認值是當前的模塊對象。
hasattr(obj, attr):
這個方法用于檢查obj是否有一個名為attr的值的屬性,返回一個布爾值。
getattr(obj, attr):
調用這個方法將返回obj中名為attr值的屬性的值,例如如果attr為'bar',則返回obj.bar。
setattr(obj, attr, val):
調用這個方法將給obj的名為attr的值的屬性賦值為val。例如如果attr為'bar',則相當于obj.bar = val。
__doc__ 查看尖的描述信息
__module__表示當前操作的對象所在的模塊
__class__表示當前操作的對象所屬的類
__init__構造方法 通過類創(chuàng)建對象自動執(zhí)行
__del__析構方法,當前對象在內存中被釋放自動斬妖執(zhí)行
__call__對象后面加括號觸發(fā)執(zhí)行
__dict__查看類或對象中的成員
__str__如果一個類中定義了此方法,那么打印此類對象時,輸出此方法的返回值
__getitem__當類中定義了一個字典的屬性成員,可以獲取
__setitem__設置修改類中字典的數(shù)據(jù)
__delitem__刪除 類中字典的數(shù)據(jù)
__metalass__其用來表示該類由 誰 來實例化創(chuàng)建
__new__觸發(fā) __init__創(chuàng)建實例
from lib.ss import a
#示例類 dog
class doges(object):
"""類的描述信息"""
def __init__(self,name,food):
self.name=name
self.food=food
self.data={}#定義一個類的字典
def __call__(self, *args, **kwargs):#對象后面加括號解執(zhí)行
print(*args)
def __str__(self):#默認輸出返回值
return self.name
def __getitem__(self):#可以獲取類的的字典
return self.data
def __setitem__(self, key, value):#可以設置類的的字典
self.data[key]=value
def __delitem__(self, key):#可以刪除類的字典的內容
del self.data[key]
dog=doges('xxx','iii')
print(dog.__doc__)
b=a()
print(b.__module__)#操作的對象的那個模塊
print(dog.__class__)#當前操作的對象的類是什么
dog('111')#
print(doges.__dict__)#查看類或對象的成員 類只打印類的成員不打印對象的成員
print(dog.__dict__)#查看類或對象的成員 對象只打印對象的成員不打印類的成員
print(dog)#打印 __str__的返回值
print(dog.__str__())#打印返回值
dog['1']=1000#觸發(fā).__setitem__()
dog['2']=1000#觸發(fā).__setitem__()
print(dog.__getitem__())
print(dog.__delitem__('1'))#刪除類中字典
print(dog.__getitem__())
#設置類的特殊方法
def func(self):
print('hello word%s'%self.name)
print()
def __init__(self,name,age):
self.name=name
self.age=age
##type參數(shù) 1:類名 2.類的基類 3.類的成員,字典格式
CAT=type('CAT',(object,),{'func':func,'__init__':__init__})
cat=CAT('喵喵',3)
cat.func()
print(cat.name,cat.age)
數(shù)據(jù)分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
SQL Server 中 CONVERT 函數(shù)的日期轉換:從基礎用法到實戰(zhàn)優(yōu)化 在 SQL Server 的數(shù)據(jù)處理中,日期格式轉換是高頻需求 —— 無論 ...
2025-09-18MySQL 大表拆分與關聯(lián)查詢效率:打破 “拆分必慢” 的認知誤區(qū) 在 MySQL 數(shù)據(jù)庫管理中,“大表” 始終是性能優(yōu)化繞不開的話題。 ...
2025-09-18CDA 數(shù)據(jù)分析師:表結構數(shù)據(jù) “獲取 - 加工 - 使用” 全流程的賦能者 表結構數(shù)據(jù)(如數(shù)據(jù)庫表、Excel 表、CSV 文件)是企業(yè)數(shù)字 ...
2025-09-18DSGE 模型中的 Et:理性預期算子的內涵、作用與應用解析 動態(tài)隨機一般均衡(Dynamic Stochastic General Equilibrium, DSGE)模 ...
2025-09-17Python 提取 TIF 中地名的完整指南 一、先明確:TIF 中的地名有哪兩種存在形式? 在開始提取前,需先判斷 TIF 文件的類型 —— ...
2025-09-17CDA 數(shù)據(jù)分析師:解鎖表結構數(shù)據(jù)特征價值的專業(yè)核心 表結構數(shù)據(jù)(以 “行 - 列” 規(guī)范存儲的結構化數(shù)據(jù),如數(shù)據(jù)庫表、Excel 表、 ...
2025-09-17Excel 導入數(shù)據(jù)含缺失值?詳解 dropna 函數(shù)的功能與實戰(zhàn)應用 在用 Python(如 pandas 庫)處理 Excel 數(shù)據(jù)時,“缺失值” 是高頻 ...
2025-09-16深入解析卡方檢驗與 t 檢驗:差異、適用場景與實踐應用 在數(shù)據(jù)分析與統(tǒng)計學領域,假設檢驗是驗證研究假設、判斷數(shù)據(jù)差異是否 “ ...
2025-09-16CDA 數(shù)據(jù)分析師:掌控表格結構數(shù)據(jù)全功能周期的專業(yè)操盤手 表格結構數(shù)據(jù)(以 “行 - 列” 存儲的結構化數(shù)據(jù),如 Excel 表、數(shù)據(jù) ...
2025-09-16MySQL 執(zhí)行計劃中 rows 數(shù)量的準確性解析:原理、影響因素與優(yōu)化 在 MySQL SQL 調優(yōu)中,EXPLAIN執(zhí)行計劃是核心工具,而其中的row ...
2025-09-15解析 Python 中 Response 對象的 text 與 content:區(qū)別、場景與實踐指南 在 Python 進行 HTTP 網(wǎng)絡請求開發(fā)時(如使用requests ...
2025-09-15CDA 數(shù)據(jù)分析師:激活表格結構數(shù)據(jù)價值的核心操盤手 表格結構數(shù)據(jù)(如 Excel 表格、數(shù)據(jù)庫表)是企業(yè)最基礎、最核心的數(shù)據(jù)形態(tài) ...
2025-09-15Python HTTP 請求工具對比:urllib.request 與 requests 的核心差異與選擇指南 在 Python 處理 HTTP 請求(如接口調用、數(shù)據(jù)爬取 ...
2025-09-12解決 pd.read_csv 讀取長浮點數(shù)據(jù)的科學計數(shù)法問題 為幫助 Python 數(shù)據(jù)從業(yè)者解決pd.read_csv讀取長浮點數(shù)據(jù)時的科學計數(shù)法問題 ...
2025-09-12CDA 數(shù)據(jù)分析師:業(yè)務數(shù)據(jù)分析步驟的落地者與價值優(yōu)化者 業(yè)務數(shù)據(jù)分析是企業(yè)解決日常運營問題、提升執(zhí)行效率的核心手段,其價值 ...
2025-09-12用 SQL 驗證業(yè)務邏輯:從規(guī)則拆解到數(shù)據(jù)把關的實戰(zhàn)指南 在業(yè)務系統(tǒng)落地過程中,“業(yè)務邏輯” 是連接 “需求設計” 與 “用戶體驗 ...
2025-09-11塔吉特百貨孕婦營銷案例:數(shù)據(jù)驅動下的精準零售革命與啟示 在零售行業(yè) “流量紅利見頂” 的當下,精準營銷成為企業(yè)突圍的核心方 ...
2025-09-11CDA 數(shù)據(jù)分析師與戰(zhàn)略 / 業(yè)務數(shù)據(jù)分析:概念辨析與協(xié)同價值 在數(shù)據(jù)驅動決策的體系中,“戰(zhàn)略數(shù)據(jù)分析”“業(yè)務數(shù)據(jù)分析” 是企業(yè) ...
2025-09-11Excel 數(shù)據(jù)聚類分析:從操作實踐到業(yè)務價值挖掘 在數(shù)據(jù)分析場景中,聚類分析作為 “無監(jiān)督分組” 的核心工具,能從雜亂數(shù)據(jù)中挖 ...
2025-09-10統(tǒng)計模型的核心目的:從數(shù)據(jù)解讀到?jīng)Q策支撐的價值導向 統(tǒng)計模型作為數(shù)據(jù)分析的核心工具,并非簡單的 “公式堆砌”,而是圍繞特定 ...
2025-09-10