python基礎(28):isinstance、issubclass、type、反射

来源:https://www.cnblogs.com/liuhui0308/archive/2019/11/15/11869857.html
-Advertisement-
Play Games

1. isinstance和issubclass 1.1 isinstance isinstance(obj,cls)檢查是否obj是否是類 cls 的對象 class Foo(object): pass obj = Foo() isinstance(obj, Foo) 實例: class Base ...


1. isinstance和issubclass

1.1 isinstance

isinstance(obj,cls)檢查是否obj是否是類 cls 的對象

class Foo(object):
  pass
  
obj = Foo()
  
isinstance(obj, Foo)

實例:

class Base(object):
  pass

class Foo(Base):
  pass

obj1 = Foo()
print(isinstance(obj1,Foo))  # 檢查第一個參數(對象)是否是第二個參數(類及父類)的實例。
print(isinstance(obj1,Base)) # 檢查第一個參數(對象)是否是第二個參數(類及父類)的實例。


obj2 = Base()
print(isinstance(obj2,Foo))  # 檢查第一個參數(對象)是否是第二個參數(類及父類)的實例。
print(isinstance(obj2,Base)) # 檢查第一個參數(對象)是否是第二個參數(類及父類)的實例。

1.2 issubclass

issubclass(sub, super)檢查sub類是否是 super 類的派生類 

class Foo(object):
  pass
 
class Bar(Foo):
  pass
 
issubclass(Bar, Foo)

實例:

class Base(object):
  pass

class Foo(Base):
  pass

class Bar(Foo):
  pass

print(issubclass(Bar,Base)) # 檢查第一個參數是否是第二個參數的 子子孫孫類

2. type

獲取當前對象是由哪個類創建。

class Foo(object):
    pass

obj = Foo()

print(obj,type(obj)) # 獲取當前對象是由那個類創建。
if type(obj) == Foo:
    print('obj是Foo類型')

實例:

class Foo(object):
    pass

class Bar(object):
    pass

def func(*args):
    foo_counter =0
    bar_counter =0
    for item in args:
        if type(item) == Foo:
            foo_counter += 1
        elif type(item) == Bar:
            bar_counter += 1
    return foo_counter,bar_counter

# result = func(Foo(),Bar(),Foo())
# print(result)

v1,v2 = func(Foo(),Bar(),Foo())
print(v1,v2)

3. 反射

3.1 什麼是反射

反射的概念是由Smith在1982年首次提出的,主要是指程式可以訪問、檢測和修改它本身狀態或行為的一種能力(自省)。這一概念的提出很快引發了電腦科學領域關於應用反射性的研究。它首先被程式語言的設計領域所採用,併在Lisp和麵向對象方面取得了成績。 

3.2 python中的反射

python面向對象中的反射:通過字元串的形式操作對象相關的屬性。python中的一切事物都是對象(都可以使用反射)。

四個可以實現自省的函數:

hasattr:

def hasattr(*args, **kwargs): # real signature unknown
    """
    Return whether the object has an attribute with the given name.
    
    This is done by calling getattr(obj, name) and catching AttributeError.
    """
    pass

getattr:

def getattr(object, name, default=None): # known special case of getattr
    """
    getattr(object, name[, default]) -> value
    
    Get a named attribute from an object; getattr(x, 'y') is equivalent to x.y.
    When a default argument is given, it is returned when the attribute doesn't
    exist; without it, an exception is raised in that case.
    """
    pass

setattr:

def setattr(x, y, v): # real signature unknown; restored from __doc__
    """
    Sets the named attribute on the given object to the specified value.
    
    setattr(x, 'y', v) is equivalent to ``x.y = v''
    """
    pass

delattr:

def delattr(x, y): # real signature unknown; restored from __doc__
    """
    Deletes the named attribute from the given object.
    
    delattr(x, 'y') is equivalent to ``del x.y''
    """
    pass

四個方法的使用例子:

class Foo:
    f = '類的靜態變數'
    def __init__(self,name,age):
        self.name=name
        self.age=age

    def say_hi(self):
        print('hi,%s'%self.name)

obj=Foo('egon',73)

#檢測是否含有某屬性
print(hasattr(obj,'name'))
print(hasattr(obj,'say_hi'))

#獲取屬性
n=getattr(obj,'name')
print(n)
func=getattr(obj,'say_hi')
func()

print(getattr(obj,'aaaaaaaa','不存在啊')) #報錯

#設置屬性
setattr(obj,'sb',True)
setattr(obj,'show_name',lambda self:self.name+'sb')
print(obj.__dict__)
print(obj.show_name(obj))

#刪除屬性
delattr(obj,'age')
delattr(obj,'show_name')
delattr(obj,'show_name111')#不存在,則報錯

print(obj.__dict__)

這四個方法適用於類和對象(一切皆對象,類本身也是一個對象)

類也是對象:

class Foo(object):
 
    staticField = "old boy"
 
    def __init__(self):
        self.name = 'wupeiqi'
 
    def func(self):
        return 'func'
 
    @staticmethod
    def bar():
        return 'bar'
 
print getattr(Foo, 'staticField')
print getattr(Foo, 'func')
print getattr(Foo, 'bar')

反射當前模塊成員:

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import sys


def s1():
    print 's1'


def s2():
    print 's2'


this_module = sys.modules[__name__]

hasattr(this_module, 's1')
getattr(this_module, 's2')

導入其他模塊,利用反射查找該模塊是否存在某個方法。

module_test.py:

# -*- coding:utf-8 -*-

def test():
    print('from the test')

index.py:

# -*- coding:utf-8 -*-
 
"""
程式目錄:
    module_test.py
    index.py
"""

import module_test as obj

#obj.test()

print(hasattr(obj,'test'))

getattr(obj,'test')()

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • app.py: from flask import Flask, render_template from datetime import datetime app = Flask(__name__) @app.route('/') def hello_world(): context = { 't ...
  • 大數取餘數(數組) 今天做學校的oj時遇到一題,問題可見一下截圖: 查遍各大論壇,都沒有遇到合適的方法,普通方法不可用,要採用數組的形式。 被除數超過long long類型,不能採用常規思路,否則會出現wrong answer。值得註意的一點,是不能用double等實數類型,只有整數類型的才可以求餘 ...
  • 一、網路編程 1.網路、網路協議(一套規則) 2.網路模型: (1)七層模型-七層 物理層(比如網線、錨)、數據鏈路層(比如電壓電流)、網路層、傳輸層、會話層、表示層、應用層(我們的活動基本都在這一層) (2)四層模型 鏈路層、網路、傳輸層、應用層 (3)每一層都有相應的協議負責交換信息或者協同工作 ...
  • 導讀:wx.showToast(OBJECT) 顯示消息提示框。 OBJECT參數說明: 參數 類型 必填 說明 最低版本 title String 是 提示的內容 icon String 否 圖標,有效值"success"、"loading" image String 否 自定義圖標的本地路... ...
  • gocron源代碼中的Action那個地方,就是個空介面類型Action interface{},可以傳遞任意類型進去,這裡是傳了個函數進去 介面是合約,任何類型只要實現了介面中的方法,那麼就可以認為實現了這個介面。對於沒有方法的介面interface{}類型,可以看做所有的類型都實現了這個介面,因 ...
  • 概述Map 集合是無序的 key-value 數據結構。Map 集合中的 key / value 可以是任意類型,但所有的 key 必須屬於同一數據類型,所有的 value 必須屬於同一數據類型,key 和 value 的數據類型可以不相同。聲明 Map //demo_14.go package m ...
  • 區別 : ① 關鍵字: 抽象類 關鍵字 abstract class 介面 interface ② 子類實現 : 抽象類 子類 通過關鍵字 extends繼承 介面 子類 通過關鍵字 implements 實現。 ③ 構造方法 : 抽象類中存在構造方法 介面中沒有構造方法 ④ 屬性和方法: 抽象類中 ...
  • 源碼中有這麼一句,這個函數要求返回的是[]cli.Command,cli.Command類型的切片,這個地方直接使用字面值初始化了一個切片返回去了 數組的字面值初始化,一般是需要指定數組的大小,可以使用...三個點來代替大小,根據後面初始化的個數來計算,下麵就是字面值初始化一個數組 切片和數組很類似 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...