Python学习笔记_Day08

简介: Python学习笔记_Day08

OOP:面向对象的编程


  • 在python中,一切皆对象


  • 对象有属性:数据属性(变量),函数属性(方法)


  • OOP编程时,需要把某些事物找出它们的共性,抽象成一个类class


  • 在具体应用时,再根据类创建实例


  • 类名建议使用驼峰的形式,如MyClass
class GameRole:
    def __init__(self, nm, wp):
        self.name = nm
        self.weapon = wp
if __name__ == '__main__':
    lb = GameRole('吕布', '方天画戟')  # 创建名为lb的实例
    print(lb.name, lb.weapon)
  • __init__是类中的特殊方法,称作构造器方法,它在创建实例的时候自动调用


  • 方法的第一个参数self,表示实例,不是关键字,可以是任意的合法名称


  • 方法中的变量名,就是函数的局部变量,只在该方法中可用


  • 绑定到实例上的变量,是实例的属性,可以在类中任意位置应用


组合


  • 两个类明显不同


  • 一个类是另一个类的组件


继承


  • 两个类有很多相同


  • 一个类是另一个类的子类


  • 子类继承父类的属性


  • 父子拥有同名方法,子类优先级高


  • 子类可以有多个父类,继承所有父类的方法


  • 执行方法时,查找的顺序是自下向上,自左向右


特殊方法


类中有一些以双下划线开头和结尾的特殊方法,也称作magic魔法方法。


re模块


https://jex.im/regulex

# 将mac地址加上冒号
192.168.1.1     000C29123456
192.168.1.2     525400A31B2C
192.168.1.3     0002231A08D3
# 思路:找到mac地址、每两个数分一组、组之间加冒号
:%s/\(..\)\(..\)\(..\)\(..\)\(..\)\(..\)$/\1:\2:\3:\4:\5:\6/

re模块常用方法

>>> import re
# match匹配到,返回匹配对象,否则返回None
>>> re.match('f..', 'food')
<_sre.SRE_Match object; span=(0, 3), match='foo'>
>>> print(re.match('f..', 'seafood'))
None
# search在字符串中匹配
>>> re.search('f..', 'food')
<_sre.SRE_Match object; span=(0, 3), match='foo'>
>>> re.search('f..', 'seafood')
<_sre.SRE_Match object; span=(3, 6), match='foo'>
>>> m = re.search('f..', 'seafood')
>>> m.group()  # 匹配对象的group方法返回匹配到的字符串
'foo'
# findall可以匹配到所有的内容
>>> re.findall('f..', 'seafood is food')
['foo', 'foo']
# finditer返回匹配对象的迭代器
>>> list(re.finditer('f..', 'seafood is food'))
[<_sre.SRE_Match object; span=(3, 6), match='foo'>, <_sre.SRE_Match object; span=(11, 14), match='foo'>]
>>> for m in re.finditer('f..', 'seafood is food'):
...   m.group()
... 
'foo'
'foo'
# split用于切割
# 以.或-作为分隔符
>>> re.split('\.|-', 'how-are-you.tar.gz')
['how', 'are', 'you', 'tar', 'gz']
# 替换
# 将X替换为python
>>> re.sub('X', 'python', 'X is good. I like X.')
'python is good. I like python.'
# 当有大量匹配时,提前把模式进行编译,可以得到更好的效率
>>> patt = re.compile('f..')
>>> patt.search('seafood')
<_sre.SRE_Match object; span=(3, 6), match='foo'>
>>> m = patt.search('seafood')
>>> m.group()
'foo'
>>> patt.findall('seafood is food')
['foo', 'foo']
相关实践学习
部署高可用架构
本场景主要介绍如何使用云服务器ECS、负载均衡SLB、云数据库RDS和数据传输服务产品来部署多可用区高可用架构。
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
28天前
|
存储 C语言 Python
【Python】学习笔记day3
【Python】学习笔记day3
27 1
|
4月前
|
SQL 分布式计算 大数据
Python+大数据学习笔记(一)
Python+大数据学习笔记(一)
44 0
|
10天前
|
Python
基于Django的Python应用—学习笔记—功能完善
基于Django的Python应用—学习笔记—功能完善
|
28天前
|
存储 C语言 芯片
【Python】学习笔记day1
【Python】学习笔记day1
33 1
|
1月前
|
算法 搜索推荐 测试技术
python排序算法及优化学习笔记1
python实现的简单的排序算法,以及算法优化,学习笔记1
33 1
|
6月前
|
jenkins 持续交付 开发工具
Python学习笔记_Devops_Day05
Python学习笔记_Devops_Day05
|
6月前
|
持续交付 开发工具 数据安全/隐私保护
Python学习笔记_Devops_Day04
Python学习笔记_Devops_Day04
|
6月前
|
JSON JavaScript 前端开发
Python学习笔记_Devops_Day02
Python学习笔记_Devops_Day02
|
6月前
|
SQL 关系型数据库 数据库
Python学习笔记_Day09
Python学习笔记_Day09
|
3月前
|
存储 算法 程序员
Python语言学习笔记-第二阶段
Python语言学习笔记-第二阶段