Python内置方法和属性应用:反射和单例(推荐)
作者:wedo实验君 发布时间:2022-08-04 03:23:48
1. 前言
python除了丰富的第三方库外,本身也提供了一些内在的方法和底层的一些属性,大家比较常用的如dict、list、set、min、max、range、sorted等。笔者最近在做项目框架时涉及到一些不是很常用的方法和属性,在本文中和大家做下分享。
2. 内置方法和函数介绍
enumerate
如果你需要遍历可迭代的对象,有需要获取它的序号,可以用enumerate, 每一个next返回的是一个tuple
list1 = [1, 2, 3, 4]
list2 = [4, 3, 2, 1]
for idx, value in enumerate(list1):
print(idx, value, list2[idx])
# 0 1 4
# 1 2 3
# 2 3 2
# 3 4 1
zip zip从参数中的多个迭代器取元素组合成一个新的迭代器;
# 给list加上序号
b = [4, 3, 2, 1]
for i in zip(range(len(b)), b):
print(i)
# (0, 4)
# (1, 3)
# (2, 2)
# (3, 1)
globals():一个描述当前执行过程中全局符号表的字典,可以看出你执行的所有过程
id(object):python对象的唯一标识
staticmethod 类静态函数注解
@staticmethod
def test():
print('this is static method')
Foo.test = test
Foo.test()
类的属性 我们来看下一个类的申明,如下:
class Foo():
"""this is test class"""
def __init__(self, name):
self.name = name
def run(self):
print('running')
# 列出类的所有成员和属性
dir(Foo)
['__class__',
'__delattr__',
'__dict__',
'__dir__',
'__doc__',
'__eq__',
'__format__',
'__ge__',
'__getattribute__',
'__gt__',
'__hash__',
'__init__',
'__init_subclass__',
'__le__',
'__lt__',
'__module__',
'__ne__',
'__new__',
'__reduce__',
'__reduce_ex__',
'__repr__',
'__setattr__',
'__sizeof__',
'__str__',
'__subclasshook__',
'__weakref__',
'run']
# 类的注释
Foo.__doc__
# 'this is test class'
# 类自定义属性
Foo.__dict__
mappingproxy({'__module__': '__main__',
'__doc__': 'this is test class',
'__init__': <function __main__.Foo.__init__(self, name)>,
'run': <function __main__.Foo.run(self)>,
'__dict__': <attribute '__dict__' of 'Foo' objects>,
'__weakref__': <attribute '__weakref__' of 'Foo' objects>})
# 类的父类
Foo.__base__
# 类的名字
Foo.__name__
类的实例化和初始化
# python类先通过__new__实例化,再调用__init__进行初始化类成员
foo = Foo('milk')
类的属性添加和访问
# 类的访问
foo.name
foo.run()
# 可以通过setattr 动态的添加属性
def method():
print("cow")
setattr(foo, "type", "cow")
setattr(foo, "getcow", method)
# cow
foo.type
foo.getcow()
# 动态删除属性 delattr
delattr(foo, "type")
# getattr 获取成员属性
if hasattr(foo, "run"): # 判断是否有属性
func = getattr(foo, "run")
func()
3. 单例模式应用
单例模式(Singleton Pattern)是 Java 中最简单的设计模式之一。单例模式要求在类的使用过程中只实例化一次,所有对象都共享一个实例。创建的方法是在实例的时候判断下是否已经实例过了,有则返回实例化过的全局实例。python是如何实现的呢?关键是找到实例化的地方,对就是前面说的__new__
class Singleton(object):
def __new__(cls, *args, **kwargs):
if not hasattr(cls, '_instance'):
cls._instance = object.__new__(cls)
return cls._instance
def __init__(self, name):
self.name = name
a = Singleton('name1')
b = Singleton('name2')
print(id(a), id(b))
print(a.name, b.name)
# 1689352213112 1689352213112
# name2 name2
4. 反射应用
反射在许多框架中都有使用到,简单就是通过类的名称(字符串)来实例化类。一个典型的场景就是通过配置的方式来动态控制类的执行,比如定时任务的执行,通过维护每个定时任务类的执行时间,在执行时间到的时候,通过反射方式实例化类,执行任务,在java中也非常的常见。
python的实现可以通过上面说的getattr获取模块中的类, 通过methodcaller来调用方法。我们来看一个简单的例子
import importlib
from operator import methodcaller
class Foo():
"""this is test class"""
def __init__(self, name):
self.name = name
def run(self, info):
print('running %s' % info)
# 类所在的模块,默认情况__main__, 可以通过Foo.__dict__ 中'__module__'获取
api_module = importlib.import_module('__main__')
# getattr获取模块中的类, 这里Foo是字符串哦
clazz = getattr(api_module, 'Foo')
# 实例化
params = ["milk"]
instance = clazz(*params)
# 方法调用, 方法也是字符串methodcaller(方法名, 方法参数)
task_result = methodcaller("run", "reflection")(instance)
# running reflection
5. 总结
本文通过分享了python内置方法和属性, 并在单例模式和反射中进行应用。希望对你有帮助,欢迎交流@mintel 要点总结如下:
dir下类
查看类自定义属性__dict__
__new__实例化类,__init__初始化类
getattr 获取属性
setattr 设置属性
记住importlib和methodcaller
来源:http://developer.51cto.com/art/202006/619255.htm
猜你喜欢
- 今天碰到一个很有意思的问题,需要将普通的 Unicode字符串转换为 Unicode编码的字符串,如下:将 \\u9500\\u552e 转
- Matplotlib效果图如下主要使用matplotlib.animation.FuncAnimation,上核心代码,# 定义静态绘图函数
- 最近在使用Python的过程中,发现网上很少提到在使用post方式时,怎么传一个数组作为参数的示例,此处根据自己的实践经验,给出相关示例:单
- urllib的基本用法urllib库的基本组成利用最简单的urlopen方法爬取网页html利用Request方法构建headers模拟浏览
- 最近,我在做网页的时候,经理老是反应网页中一些栏目中没有背景图片。我说:背景图片有的,你刷新看看。但是他说:我可以刷新看看,但是你不能老是让
- 一. 引言在数据分析和可视化领域,数据的有效呈现是至关重要的。Python作为一种强大的编程语言,提供了多种数据可视化工具和库。其中,Plo
- 与没有数据库的网站相比,数据库的存取会降低你的系统性能。但是大多数情况下,网站和数据库有密不可分的关系,正是数据库给站点提供了大容量、多样性
- string操作在编程中具有极高的频率,那么string中有哪些有用的方法呢?使用strings直接操作Comparefunc Compar
- 1、from子句组装来自不同数据源的数据; 2、where子句基于指定的条件对记录行进行筛选; 3、group&nb
- hasattr(object, name)作用:判断对象object是否包含名为name的特性(hasattr是通过调用getattr(oj
- 在分析sIFR之前,先来快速的了解一下sIFR是什么,以及它是如何工作的。sIFR表示scalable Inman Flash Replac
- 工欲善其事必先利其器,Python开发利器Pycharm常用快捷键以及配置如下,相信有了这些快捷键,你的开发会事半功倍一 常用快捷键编辑类:
- python中的turtle库是3.6版本中新推出的绘图工具库,那么如何使用呢?下面小编给大家分享一下。首先打开pycharm软件,右键单击
- 前言:大部分的文件上传功能都是用input标签实现,这样就完全可以把它看作一个输入框,可以通过send_keys()指定文件进行上传了。本章
- 子曰:“工欲善其事,必先利其器。”学习Python就需要有编译Python程序的软件,一般情况下,我们选择在Python官网下载对应版本的P
- Python提供了多个内置模块用于操作日期时间,像calendar,time,datetime。time模块我在之前的文章已经有所介绍,它提
- asp使用WScript.Shell获取电脑的网络配置信息Option Explicit Dim WSHShe
- 一、连接MYSQL:格式: mysql -h主机地址 -u用户名 -p用户密码1、例1:连接到本机上的MYSQL。首先在打开DOS窗口,然后
- 现在网页的设计都讲究整体统一风格,无论是网页的文字、图像,还是浏览器的滚动条都要求颜色和风
- 1、先说恢复误删单元格的操作场景:不小心把某个cell给cut了,或者删除了单元格(前提不要关闭notebook窗口)。解决方法: 先按Es