哈喽兄弟们,今天咱们分享一下类的定义和使用。
在Python中,类表示具有相同属性和方法的对象的集合。在使用类时,需要先定义类,然后再创建类的实例,通过类的实例就可以访问类中的属性和方法了。
在Python中,类的定义使用class关键字来实现,语法如下:
class ClassName:
“”“类的帮助信息”“” # 类文本字符串
statement # 类体
参数说明
class Geese:
“”“大雁类”“”
pass
定义完成后,并不会真正创建一个实例。这就好比一个汽车的设计图。设计图可以告诉你汽车看上去怎么样,但设计图本身不是一个汽车。你不能开走它,它只能用来建造真正的汽车,而且可以使用它制造很多汽车。那么如何创建实例呢?
class语句本身并不创建该类的任何实例。所以在类定义完成以后,可以创建类的实例,即实例化该类的对象。创建类的实例的语法如下:
ClassName(parameterlist)
参数说明
例如,创建上面Geese类的实例,可以使用下面代码:
# 创建类
class Geese:
“”“大雁类”“”
pass
# 创建实例
wildGoose = Geese()
print(wildGoose)
执行上面代码后,将显示类似下面的内容:
从上面的执行结果中可以看出,wildGoose是Geese类的实例。
在创建类后,类通常会自动创建一个__init_()方法。该方法是一个特殊的方法,类似JAVA 语言中的构造方法。
每当创建一个类的新实例时,Python都会自动执行它。init()方法必须包含一个参数,并且必须是第一参数。self参数是一个指向实例本身的引用,用于访问类中的属性和方法。
在方法调用时会自动传递实际参数self。因此,当__init__()方法只有一个参数时,在创建类的实例时,就不需要指定参数了。
例如,下面乃然以大雁为例,并创建__init__()方法,代码如下:
# 创建类
class Geese:
“”“大雁类”“”
def __init__(self):
print("我是大雁类")
wildGoose = Geese()
常见错误
在为类创建__init__()方法时,在开发环境中运行下面的代码:
# 创建类
class Geese:
“”“大雁类”“”
def __init__(): # 构建方法
print("我是大雁类")
wildGoose = Geese() # 创建大雁实例
运行上述代码,将抛出以下异常:
在__init__()方法中,除了self参数外,还可以自定义一些参数,参数间使用逗号“,”进行分隔。
例如,下面的代码将在创建__init__()方法时,再指定3个参数,分别是beak、wing和claw:
# 创建类
class Geese:
“”“大雁类”“”
def __init__(self, beak, wing, claw):
print("我是大雁类!我有一下特征:")
print(beak)
print(wing)
print(claw)
beak_1 = “喙”
wing_1 = “翅膀”
claw_1 = “爪”
wildGoose = Geese(beak_1, wing_1, claw_1)
运行上面代码,将显示以下结果:
类的成员主要由实例方法和数据成员组成。在类中创建了类的成员后,可以通过类的实例进行访问。下面进行详细介绍。
所谓实例方法是指在类中定义函数。该函数是一种在类的实例上操作的函数。同__init__()方法一样,实例方法的第一参数必须是self,并且必须包含一个self参数。创建实例的方法的语法格式如下:
def functionName(self,parameterlist):
block
参数说明
实例创建完成后,可以通过类的实例名称和点(.)操作符进行访问。具体的语法格式如下:
instanceName.functionName(parametervalue)
参数说明
数据成员是指类中定义的变量,即属性,根据定义位置,又可以分为类属性和实例属性,下面分别进行介绍。
类属性
类属性是指在定义类中,并且在函数体外的属性。类属性可以在类的所有实例之间共享值,也就是在所有实例化的对象中公用。
例如,定义一个雁类,在该类中定义3个属性,用于记录雁的特征,代码如下:
class Geese:
"""大雁类"""
beak_1 = "喙,比较尖" # 定义类属性(喙)
wing_1 = "翅膀,比较大"
claw_1 = "爪,行走自如"
def __init__(self):
print("我是大雁类!我有一下特征:")
print(Geese.beak_1) # 输出喙的属性
print(Geese.wing_1)
print(Geese.claw_1)
创建上面的类Geese,然后创建类的实例,代码如下:
goose = Geese() # 实例化一个雁的对象
运行上面代码创建Geese类的实例后,将显示以下内容:
实例属性
实例属性是指定义在类的方法中的属性,只作用于当前实例中。
例如,定义一个雁类Geese,在该类的__init__()方法中定义3个实例属性,用于记录雁类的特征,代码如下:
# 创建类
class Geese:
"""大雁类"""
def __init__(self):
self.beak_1 = "喙,比较尖" # 定义实例属性(喙)
self.wing_1 = "翅膀,比较大"
self.claw_1 = "爪,行走自如"
print("我是大雁类!我有一下特征:")
print(self.beak_1) # 输出喙的属性
print(self.wing_1)
print(self.claw_1)
创建上面的类Geese,然后创建类的实例,代码如下:
goose = Geese() # 实例化一个雁的对象
运行上面代码创建Geese类的实例后,将显示以下内容:
说明
实例属性只能通过实例名访问。如果通过类名访问实例属性,将抛出如图所示的异常。
对于实例的属性也可以通过实例名称修改,与类不同,通过实例名称修改实例属性后,并不能影响该类的其他实例中相应的实例属性值。
例如,定义一个雁类,并在__init__()方法中定义一个实例属性,然后创建两个Geese类的实例,并修改一个实例属性,最后分别输出实例属性,代码如下:
# 创建类
class Geese:
"""大雁类"""
def __init__(self):
self.beak_1 = "喙,比较尖" # 定义实例属性(喙)
print(self.beak_1) # Python学习交流君羊 279199867
goose1 = Geese() # 创建Geese实例1
goose2 = Geese() # 创建Geese实例2
goose1.beak_1 = "喙,比长鹅尖" # 修改实例属性
print("goose1的beak_1属性:", goose1.beak_1)
print("goose2的beak_1属性:", goose2.beak_1)
运行上面代码,将显示以下内容:
在类的内部可以定义属性和方法,而在类的外部则可以直接调用属性或方法来操作数据,从而隐藏了类内部的复杂逻辑。但Python并没有对属性和方法的访问权限进行限制。
为了保证类内部的某些属性或方法不被外部所访问,可以在属性或方法名前面添加单下划线(_foo)、双下划线(__foo)或者首尾加双下划线( __ foo __),从而限制访问权限。
其中,单下划线、双下划线、首尾双下划线的作用如下:
例如,创建一个Swan类,定义保护属性_neck_swan,并在__init__()方法中访问该属性,然后创建Swan类的实例,并通过实例名输出保护属性_neck_swan,代码如下:
class Swan:
"""天鹅类"""
_neck_swan = "天鹅脖子长" # 创建私有属性
def __init__(self):
print("__init__():", Swan._neck_swan)
swan = Swan() # 创建Swan类
print("直接访问:", swan._neck_swan)
执行以上代码,将显示以下内容:
从上面的运行结果中可以看出:保护属性可以通过实例名访问。
例如,创建一个Swan类,定义保护属性__neck_swan,并在__init__()方法中访问该属性,然后创建Swan类的实例,并通过实例名输出保护属性__neck_swan,代码如下:
class Swan:
"""天鹅类"""
__neck_swan = "天鹅脖子长" # 创建私有属性
def __init__(self):
print("__init__():", Swan.__neck_swan)
swan = Swan() # 创建Swan类
print("加入类名:", swan._Swan__neck_swan)
print("直接访问:", swan.__neck_swan)
运行上面代码,将输出如图所示的结果:
从上面的运行结果可以看出:私有属性可以通过“类名.属性名”方式访问,也可以通过“实例名.类名__xxx”方式访问,但是不能直接通过“实例名.属性名”方式访问。
好了,兄弟们,今天的分享就到这结束了,最后再分享一套Python教程给大家,涵盖了常见的爬虫案例,非常详细。
Python爬虫实战100例