Python 面向对象之反射

Python 面向对象之反射

【一】概念

  • 反射是指通过对象的属性名或者方法名获取对象的属性或调用方法的能力
  • 反射还指的是在程序额运行过程中可以动态获取对象的信息(属性和方法)

【二】四个内置函数

  • 又叫做反射函数

  • 万物皆对象(整数、字符串、函数、模块、类等等)

  • 万物皆对象(整数、字符串、函数、模块、类等等)

  • 万物皆对象(整数、字符串、函数、模块、类等等)

  • 这里提到的对象都是大概念的对象

【1】hassttr

(1)概念
  • hasattr(object, str)

  • 判断对象是否有相应属性或者方法

  • 第一个参数是对象,第二个参数属性或者方法的字符串

  • 返回值为bool值,有则True,无则False

  • 注意:类无法找到实例属性

(2)代码
class A:name = "bruce"def __init__(self):self.age = 18def eat(self):print(f"{self.name}eating")# 查看类是否具有相应属性和方法
print(hasattr(A, "name"))  # True
print(hasattr(A, "age"))  # False
print(hasattr(A, "eat"))  # True# 查看对象是否具有相应属性和方法
a = A()
print(hasattr(a, "name"))  # True
print(hasattr(a, "age"))  # True
print(hasattr(a, "eat"))  # True

【3】getattr

(1)概念
  • hasattr(object, name[, default])

  • 获取对象的属性或者方法

  • 第一个参数是对象,第二个参数属性或者方法的字符串,第三个参数是找不到返回的默认值

  • 返回值为属性或者方法或默认值,找不到也没有默认值会报错

(2)代码
class A:name = "bruce"def __init__(self):self.age = 18def eat(self):print(f"{self.name} is eating")a = A()
print(getattr(a, "name"))  # bruce
print(getattr(a, "age"))  # bruce
res = getattr(a, "eat")  # # <bound method A.eat of <__main__.A object at 0x000>>
res()  # bruce is eating
# getattr(a, "nname") # 报错
print(getattr(a, "nname", "找不到"))  # 找不到

【3】setattr

(1)概念
  • setattr(object, str)

  • 设置对象的属性或者方法

  • 第一个参数是对象,第二个参数是属性的字符串或者方法地址

  • 已有就修改,没有就添加

  • 注意:给实例添加的方法是属性

(2)代码
class A:name = "bruce"def __init__(self):self.age = 18def eat(self):print(f"{self.name} is eating")a = A()
setattr(a, "name", "lily")
print(getattr(a, "name"))  # lily
setattr(a, "age", 20)
print(getattr(a, "age"))  # 20def func(self):print("类外的函数1")
# 给实例添加的一个属性,他是方法
setattr(a, "func", func)
print(a.__dict__)  # {'age': 20, 'name': 'lily', 'func': <function func at 0x000>}
a.func(a)  # 类外的函数1def func(self):print("类外的函数2")
# 给类添加了一个方法
setattr(A, "func", func)
A.func(a)  # 类外的函数2
a.func(a)  # 类外的函数1

【4】delattr

(1)概念
  • delattr(object, str)

  • 删除对象的属性或者方法

  • 第一个参数是对象,第二个参数是属性或者方法的字符串

  • 没有返回值,删除没有的会报错

  • 注意通过实例无法删除类属性或者方法

(2)代码
class A:name = "bruce"def __init__(self):self.age = 18def eat(self):print(f"{self.name} is eating")# 对属性操作
a = A()
# delattr(a, "name") # 无法删除
delattr(a, "age")
print(getattr(a, "age", "找不到"))  # 找不到
delattr(A, "name")
print(getattr(A, "name", "找不到"))  # 找不到# 对方法操作
a = A()
# delattr(a, "eat") # 无法删除
print(getattr(A, "eat", "找不到"))  # 找不到

【三】应用

【1】反射当前模块成员

  • 用于查看当前模块下的
import sysclass A:pass
class B(A):pass
def func():passmodule_member = sys.modules[__name__]
print(module_member)
# <module '__main__' from 'D:\\Python\\PythonProjects\\My_projects\\tets_tempory\\main.py'>
print(hasattr(module_member, "B"))  # True
print(hasattr(module_member, "func"))  # True

【2】动态导入模块

  • 通过importlib模块导入所需要的模块,通过ImportError异常判断模块是否能导入
  • 通过getattr反射获取模块的方法,通过AttributeError异常判断该模块是否具有这个方法
import importlibmodule_name = input("module name:>>>")
method_name = input("method name:>>>")
try:module = importlib.import_module(module_name)method = getattr(module, method_name)method()
except ImportError:print("module not found")
except AttributeError:print("method not found")

【3】动态创建对象

class FirePeaShooter:def introduce(self):print("I`m FirePeaShooter")class IcePeaShooter:def introduce(self):print("T`m IcePeaShooter")type = input("input type (fire or ice):>>>")
global_class = globals()if "fire" in type:class_type = "FirePeaShooter"obj = global_class[class_type]()obj.introduce()
elif "ice" in type:class_type = "IcePeaShooter"obj = global_class[class_type]()obj.introduce()
else:print("wrong")

【四】总结

请添加图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/604288.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第02章_变量与进制

第02章_变量与进制 讲师&#xff1a;尚硅谷-宋红康&#xff08;江湖人称&#xff1a;康师傅&#xff09; 官网&#xff1a;http://www.atguigu.com 本章专题脉络 1、关键字(keyword) 定义&#xff1a;被C语言赋予了特殊含义&#xff0c;用做专门用途的字符串&#xff08;或单…

力扣:438. 找到字符串中所有字母异位词 题解

Problem: 438. 找到字符串中所有字母异位词 438. 找到字符串中所有字母异位词 预备知识解题思路复杂度Code其它细节推荐博客或题目博客题目滑动窗口哈希表 预备知识 此题用到了双指针算法中的滑动窗口思想&#xff0c;以及哈希表的运用。c中是unordered_map。如果对此不了解的u…

Android 车联网——PowerHalService介绍(九)

在前面文章介绍 CarPowerManagementService 时候,我们了解到 VehicleHAL 接收到电源变化的信号后,通过 PowerHalService 分发给 CarPowerManagementService 的。而且 CarPowerManagementService 的很多方法也都是调用到 PowerHalService 中。这一节我们来看一下 PowerHalServ…

二、UI文件设计与运行机制

一、UI文件设计与运行机制 1、创建工程 2、添加控件&#xff0c;实现按钮点击 &#xff08;1&#xff09;添加控件 &#xff08;2&#xff09;添加信号和槽 2、分析项目结构 test_02test_02.pro Qt工程文件Headerswidget.h 设计的窗体类的头文件Sourcesmain.cpp 主程序入…

metartc5_jz源码阅读-yang_push_h264_encodeVideo

//编码rtp的视频buffer&#xff0c;发送给p2p对端。 int32_t yang_push_h264_encodeVideo(YangRtcSession *session, YangPushH264Rtp *rtp,YangRtpPacket *pkt) {int err 0;//用videoRtpBuffer中的数据填充rtp->buf.yang_init_buffer(&rtp->buf, yang_get_rtpBuffe…

如何在CMakeLists.txt设置多线程编译加速

在windows cmake-gui 编译时候&#xff0c;没有像linux 一样有make -j 实现多线程编译 但是没有多线程编译速度会很慢&#xff0c;为了windows 编译程序时候实现多线程加速可以在 cmakelists.txt 添加下面两句就可以实现多线程编译 set( CMAKE_C_FLAGS "${CMAKE_C_FLA…

RabbitMQ消息可靠性保证机制3--消费端ACK机制

消费端ACK机制 ​ 在这之前已经完成了发送端的确认机制。可以保证数据成功的发送到RabbitMQ&#xff0c;以及持久化机制&#xff0c;然尔这依然无法完全保证整个过程的可靠性&#xff0c;因为如果消息被消费过程中业务处理失败了&#xff0c;但是消息却已经被标记为消费了&…

3.2.6 使用ROPES软件开发模型做设计、实现、测试

3.2.6 使用ROPES软件开发模型做设计 使用ROPES软件开发模型进行设计涉及将系统开发过程分为分析、设计和优化的不同阶段。 分析模型与设计模型 分析模型&#xff1a;定义系统所需的属性集合&#xff0c;它是理解和表述系统需求的第一步。它更注重于"应该做什么"而…

cygwin安装make工具

1. 下载安装包。 2. 运行setup-x86_64.exe 3. 选择安装源&#xff08;Mirror&#xff09;&#xff1a;在 Cygwin 安装程序的窗口中&#xff0c;选择 "Install from Internet" 选项&#xff0c;然后点击 "Next" 继续。 4. 选择安装目录&#xff1a;在 &q…

rk3588中编译带有ffmpeg的opencv

有朋友有工程需要&#xff0c;将视频写成mp4&#xff0c;当然最简单的方法当然是使用opencv的命令 cv::VideoWriter writer;bool bRet writer.open("./out.mp4", cv::VideoWriter::fourcc(m, p, 4, v), 15, cv::Size(640, 512), 1); 但是奈何很难编译成功&#xff…

Python | 基于Mediapipe框架的手势识别系统

一、项目要求 1、题目 本题着力于解决会商演示系统中的非接触式人机交互问题&#xff0c;具体而言&#xff0c;其核心问题就是通过计算机视觉技术实现对基于视频流的手势动作进行实时检测和识别。通过摄像头采集并识别控制者连续的手势动作&#xff0c;完成包括点击、平移、缩放…

离散数学1

注&#xff1a;线性代数已经更新了最大部分的内容&#xff0c;因此过段时间再补充剩余内容。 小王能歌善舞。因此&#xff0c;小王必须得会唱歌也必须得会跳舞&#xff0c;才满足题意 小王能唱歌或者小王能跳舞。因此&#xff0c;小王会唱歌也会跳舞满足。小王不会唱歌但会跳舞…

JavaScript常用事件演示

文章目录 一、在JavaScript中什么是事件&#xff1f;二、什么是JavaScript 常用事件&#xff1f;三、常用JS事件代码示例:四、事件总结 一、在JavaScript中什么是事件&#xff1f; JavaScript 使我们有能力创建动态页面。事件是可以被 JavaScript 侦测到的行为。 网页中的每个…

C++|【34】C++中的const

文章目录 constconst最基本的用法const和指针const和类 const const最基本的用法 用于限定a的大小&#xff0c;使a变成一个恒定不变的值。 应用场景&#xff1a;比如设置一些和标准相关的值&#xff0c;如上下限等等。 const和指针 指针总是包含两部分信息&#xff0c;一个是…

如何信任机器学习模型的预测结果?

在本篇中&#xff0c;我将通过一个例子演示在 MATLAB 如何使用 LIME 进行复杂机器学习模型预测结果的解释。 我使用数据集 carbig&#xff08;MATLAB 自带的数据集&#xff09;训练一个回归模型&#xff0c;用于预测汽车的燃油效率。数据集 carbig 是 70 年代到 80 年代生产的汽…

docker的基础知识

介绍docker 什么是docker Docker是一种开源的容器化平台&#xff0c;可以让开发人员将应用程序与其依赖的运行时环境一起打包到一个称为容器的独立单元中。这个容器可以在任何支持Docker的机器上运行&#xff0c;提供了一种快速和可移植的方式来部署应用程序。Docker的核心组件…

Python库学习(十四):ORM框架-SQLAlchemy

1.介绍 SQLAlchemy 是一个用于 Python 的 SQL 工具和对象关系映射&#xff08;ORM&#xff09;库。它允许开发者通过 Python 代码而不是 SQL查询语言来操作数据库。SQLAlchemy 提供了一种灵活且强大的方式来与关系型数据库交互&#xff0c;支持多种数据库后端&#xff0c;如 P…

spring oauth2 authorization server 配置源码解析

版本 1.2.1 源码 OAuth2 授权服务器配置 org.springframework.security.oauth2.server.authorization.config.annotation.web.configuration.OAuth2AuthorizationServerConfiguration Configuration(proxyBeanMethods false) public class OAuth2AuthorizationServerConfi…

【十七】【动态规划】DP41 【模板】01背包、416. 分割等和子集、494. 目标和,三道题目深度解析

动态规划 动态规划就像是解决问题的一种策略&#xff0c;它可以帮助我们更高效地找到问题的解决方案。这个策略的核心思想就是将问题分解为一系列的小问题&#xff0c;并将每个小问题的解保存起来。这样&#xff0c;当我们需要解决原始问题的时候&#xff0c;我们就可以直接利…

小米红米Note9 Pro 5G刷PixelOS,并安装kali nethunter

1.解锁BL 小米解锁BL&#xff0c;网上有很多教程&#xff0c;如果需要刷机的话&#xff0c;需要提前7天准备。因为小米解锁需要登录账号&#xff0c;并使用官方解锁工具进行解锁&#xff0c;这里不做过多阐述。 2.下载相关文件 可以访问该地址下载recovery和rom&#xff1a;…