Python中的type与isinstance的区别详解

目录
  • type()函数
  • isinstance()函数

Python中的type()函数和isinstance()函数是两个常用的类型判断函数,它们可以用来判断变量的类型,接下来让我们一起来看一下它们的用法。

type()函数

type()函数用于获取一个变量的类型,它的语法是:type(变量)。

调之后会返回变变量的类型,下面是一个简单的例子:

1、获取变量的类型

a = 123
b = "123"
c = (123,)

print(type(a))  # 输出<class 'int'>
print(type(b))  # 输出<class 'str'>
print(type(c))  # 输出<class 'tuple'>
print(type(None))   # 输出<class 'NoneType'>

2、获取函数、类、模块等的类型

import time

def test():
    print(time.time())

test()
print(type(test))  # 输出 <class 'function'>
print(type(object))  # 输出<class 'type'>
print(type(time))  # 输出<class 'module'>

3、使用type函数动态创建类

type()函数接收三个参数:

  • 类名(字符串)
  • 父类(元组)
  • 类属性和方法(字典)

使用案例:

# 定义一个函数作为类方法
def say_hi(self):
    print(f"大家好,我的公众号是: {self.name},欢迎大家关注哟~")

MyClass = type('MyClass', (object,), {"name": "小博测试成长之路",
                                      "age": 18, "say": say_hi})

MyClass().say()

上面脚本运行后的输出结果:

关于使用type来动态创建类的话,之前我也没接触过这种用法,等后面有时间接触的多了之后,还会再去回过头仔细地了解一下具体的用法和使用场景,这次先简单介绍一下。

isinstance()函数

isinstance()函数一般用来检查一个对象是否是另一个对象的实例。isinstance()函数会考虑继承关系,如果一个对象是指定类或其子类的实例,isinstance()函数都会返回True。同时,可以使用isinstance进行多种类型的判断,只需要将要判断的类型以元组的形式传递给isinstance()函数即可。

x = 5
y = "5"
print(isinstance(x, object))  # 输出 True
print(isinstance(x, int))  # 输出 True
多种类型的判断:
print(isinstance(y, (int, str)))  # 输出 True
继承关系的判断:
class A:
    pass

class B(A):
    pass

obj = B()
print(isinstance(obj, A))  # 输出 True

综上所述,type()函数和isinstance()函数都可以用来检查对象的类型,但它们的用途和适用场景有所不同。在处理继承关系时,isinstance()函数更加灵活和实用。

到此这篇关于Python中的type与isinstance的区别详解的文章就介绍到这了,更多相关Python type与isinstance内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Python进阶之列表推导与生成器表达式详解

    目录 内置序列类型 列表推导与生成器表达式 列表推导 生成器表达式 总结 在python学习的过程中,我们最先接触到的就是python的数组,元组,字典等基础类型,但很少有人深入讨论python的内置序列类型以及它们的高级使用姿势. 深度学习python的内置序列,不仅能让我们编写的API更加的易用简介,也能够更好的理解python中各种序列的特性. 在本文中,我们就来一起解锁python内置序列的高级用法,玩转pyhon序列. 内置序列类型 python中有很多的序列类型,主要可以分为以下两类

  • Python采集二手车数据的超详细讲解

    目录 数据采集 发送请求 明确需求: 解析数据 保存数据 总结 数据采集 XPath,XML路径语言的简称.XPath即为XML路径语言(XML Path Language),它是一种用来确定XML文档中某部分位置的语言.XPath主要用于解析XML文档,可以用来获取XML文档中某个元素的位置.属性值等信息.XPath可以用于XML文档解析.XML数据抽取.XML路径匹配等方面. 发送请求 首先,我们要进行数据来源分析,知道我们的需求是什么? 明确需求: 明确采集网站是什么? 明确采集数据是什么

  • Python中字典列表中删除重复项

    要从字典列表中删除重复项: 使用字典推导来遍历列表. 使用每个 id 属性的值作为键,使用字典作为值. 使用 dict.values() 方法只获取唯一的字典. 使用 list() 类将结果转换为列表. list_of_dictionaries = [ {'id': 1, 'site': 'jiyik.com'}, {'id': 2, 'site': 'google.com'}, {'id': 1, 'site': 'jiyik.com'}, ] result = list( { diction

  • Python进阶之利用+和*进行列表拼接

    目录 引言 对序列使用+和* 由列表组成的列表 嵌套列表创建的陷阱 总结 引言 python作为一款深受大家喜爱的语言,一直都在时代的风口浪尖吸引了很多的人学习.在我们学习python的过程中,有一个非常常见的语法,那就是利用+和*进行序列的拼接以及其他操作.但是孰不住这个操作存在一个陷阱,今天就带大家从使用+和*进行拼接出发认识一个大家非常容易犯的代码错误.话不多说我们开始吧. 对序列使用+和* 在编写python的过程中,我们默认python的序列是支持+和*的操作的.例如在对序列相加的过程

  • python简单几步实现时间日期处理到数据文件的读写

    目录 正文 时间日期的处理 数据文件读写 # 数据库 正文 大家好,上一篇讲了如何创建python如何创建类,抽象类,访问限制的说明.今天说说python的相关技能,比如将时间日期的处理,数据文件的读写,以及数据库的简单操作. 时间日期的处理 python中时间处理主要使用的库是 datetime 1.datetime是内置模块,不需要安装,直接使用 import datetime 2.datetime里面有五个类: date类:表示日期的类 time类:表示时间的类 datetime类:表示时

  • Python中set与frozenset方法和区别详解

    set(可变集合)与frozenset(不可变集合)的区别: set无序排序且不重复,是可变的,有add(),remove()等方法.既然是可变的,所以它不存在哈希值.基本功能包括关系测试和消除重复元素. 集合对象还支持union(联合), intersection(交集), difference(差集)和sysmmetric difference(对称差集)等数学运算. sets 支持 x in set, len(set),和 for x in set.作为一个无序的集合,sets不记录元素位

  • 对python 中re.sub,replace(),strip()的区别详解

    1.strip(): str.strip([chars]);去除字符串前面和后面的所有设置的字符串,默认为空格 chars -- 移除字符串头尾指定的字符序列. st = " hello " st = st.strip() print(st+"end") 输出: 如果设置了字符序列的话,那么它会删除,字符串前后出现的所有序列中有的字符.但不会清除空格. st = "hello" st = st.strip('h,o,e') print(st) 因

  • 对python中数组的del,remove,pop区别详解

    以a=[1,2,3] 为例,似乎使用del, remove, pop一个元素2 之后 a都是为 [1,3], 如下: >>> a=[1,2,3] >>> a.remove(2) >>> a [1, 3] >>> a=[1,2,3] >>> del a[1] >>> a [1, 3] >>> a= [1,2,3] >>> a.pop(1) 2 >>>

  • Python中__new__与__init__方法的区别详解

    在python2.x中,从object继承得来的类称为新式类(如class A(object))不从object继承得来的类称为经典类(如class A()) 新式类跟经典类的差别主要是以下几点: 1. 新式类对象可以直接通过__class__属性获取自身类型:type 2. 继承搜索的顺序发生了改变,经典类多继承时属性搜索顺序: 先深入继承树左侧,再返回,开始找右侧(即深度优先搜索);新式类多继承属性搜索顺序: 先水平搜索,然后再向上移动 例子: 经典类: 搜索顺序是(D,B,A,C) >>

  • Python中关键字global和nonlocal的区别详解

    前言 终于下定决心学习Python了.既然从头开始,就需要认认真真. 首先需要说的是,我是初学Python,这篇文章只是用于展示global和nonlocal关键字的区别,是很简单的知识点,如果你已经学过,可以绕道.因为不经常写博客,而且是个Python小白,所以内容有些啰嗦... 两个关键词都用于允许在一个局部作用域中使用外层的变量. global 表示将变量声明为全局变量 nonlocal 表示将变量声明为外层变量(外层函数的局部变量,而且不能是全局变量) 注意:我使用的是Python3.6

  • python数据类型判断type与isinstance的区别实例解析

    在项目中,我们会在每个接口验证客户端传过来的参数类型,如果验证不通过,返回给客户端"参数错误"错误码. 这样做不但便于调试,而且增加健壮性.因为客户端是可以作弊的,不要轻易相信客户端传过来的参数. 验证类型用type函数,非常好用,比如 >>type('foo') == str True >>type(2.3) in (int,float) True 既然有了type()来判断类型,为什么还有isinstance()呢? 一个明显的区别是在判断子类. type(

  • 浅谈python 中的 type(), dtype(), astype()的区别

    如下所示: 函数 说明 type() 返回数据结构类型(list.dict.numpy.ndarray 等) dtype() 返回数据元素的数据类型(int.float等) 备注:1)由于 list.dict 等可以包含不同的数据类型,因此不可调用dtype()函数 2)np.array 中要求所有元素属于同一数据类型,因此可调用dtype()函数 astype() 改变np.array中所有数据元素的数据类型. 备注:能用dtype() 才能用 astype() 测试代码: import nu

  • Golang中的Slice与数组及区别详解

    在golang中有数组和Slice两种数据结构,Slice是基于数组的实现,是长度动态不固定的数据结构,本质上是一个对数组字序列的引用,提供了对数组的轻量级访问.那么我们今天就给大家详细介绍下Golang中的Slice与数组, 1.Golang中的数组 数组是一种具有固定长度的基本数据结构,在golang中与C语言一样数组一旦创建了它的长度就不允许改变,数组的空余位置用0填补,不允许数组越界. 数组的一些基本操作:      1.创建数组: func main() { var arr1 = [.

  • Python 中的函数装饰器和闭包详解

    函数装饰器可以被用于增强方法的某些行为,如果想自己实现装饰器,则必须了解闭包的概念. 装饰器的基本概念 装饰器是一个可调用对象,它的参数是另一个函数,称为被装饰函数.装饰器可以修改这个函数再将其返回,也可以将其替换为另一个函数或者可调用对象. 例如:有个名为 decorate 的装饰器: @decorate def target(): print('running target()') 上述代码的写法和以下写法的效果是一样的: def target(): print('running targe

  • python中的迭代器,生成器与装饰器详解

    目录 迭代器 生成器 装饰器 总结 迭代器 每一个可迭代类内部都要实现__iter__()方法,返回一个迭代类对象,迭代类对象则定义了这个可迭代类如何迭代. for循环调用list本质上是是调用了list的迭代器进行迭代. # 对list进行for循环本质上是调用了list的迭代器 list = [1,2,3,4] # for 循环调用 for elem in list: print(elem) # 迭代器调用 list_iter = list.__iter__() while True: tr

随机推荐