Python核心

模块 Module
  • 模块的导入有3种方式:
    本质:使用变量名“模块”关联模块地址
    --- import 模块 as 别名

    本质:将指定成员导入到当前模块作用域中 (小心冲突)
    --- from 模块 import 成员1,成员2
    --- from 模块 import *

"""
    Python 核心 - 模块 - 3种调用方式
"""
# 第一种导入方式, As: 模块别名
import module01 as m01

m01.fun01()
cls01 = m01.Class01()
cls01.fun02()

# 第二种导入方式
from module01 import Class01, fun01

Class01.fun02()
fun01()

# 第三种导入方式
from module01 import *

Class01.fun02()
fun01()
  • 隐藏成员不能被 from import * 导入
"""
练习02: Python 核心 - 模块 - 隐藏成员不能被 from import * 导入
"""
from module02 import *

fun01()
# 隐藏成员(单下划线开头) 不能被 from import * 导入
_fun02()  # name '_fun02' is not defined

# 查看当前文档注释
# 练习02: Python 核心 - 模块 - 隐藏成员不能被 from import * 导入
print(__doc__)
# 查看当前文档绝对路径
# C:/Users/xxx/python/day01/main/exercise02.py
print(__file__)
# 主模块叫做: __main__
# 非主模块叫做:真名
print(__name__)  # __main__
# 作用1: 不是主模块不执行。(测试代码)
# 作用2: 只有主模块才执行
# 使用:  if __name__ == "__main__":
隐藏成员
只有在主模块测试时,才会运行

限制只有从当前模块才能运行
内置模块 time
# 获取当前时间戳
timestamp = time.time()
print(timestamp)  # 1652175860.618811

# 获取当前时间元组
# time.struct_time(tm_year=2022, tm_mon=5, tm_mday=10, tm_hour=17, tm_min=47, tm_sec=22, tm_wday=1, tm_yday=130, tm_isdst=0)
tuple_time = time.localtime()
print(tuple_time)
# 时间戳转元组
tuple_time = time.localtime(timestamp)
print(tuple_time)
# 元组转时间戳
timestamp = time.mktime(tuple_time)
print(timestamp)  # 1652177292.0
包 Package

包 package
---模块 module
--------.....
--------.....

# from 包.模块 import 成员变量 as 别名
# from 包.包.模块 import 成员变量 as 别名
# from common.list_helper import list_skill as ls
from skill_system.skill_deployer import list_deployer

# ls()
list_deployer()
异常处理 Error

在 python 中异常(Exception)是总的错误处理父类,其他的个种类型错误 都是它的子类。例如 ValueError 、 NotImplementError 等等......
在 python 中错误就以一种异常, Exception 是错误基类

  • 常用的异常类型:
    --- 名称异常 NameError : 变量未定义
    --- 类型异常 TypeError: 不同数据类型进行运算
    --- 索引异常 IndexError: 超出索引范围
    --- 属性异常 AttributeError: 对象属性不存在
    --- 键异常 KeyError: 没有对应名称的键
    --- 未实现异常 NotImplementError: 没有实现的父类异常
    --- 异常基类 Exception

  • 异常处理完整流程

"""
练习05: Python 核心 - 异常处理完整流程
"""


def div_zero():
    person_count = int(input("请输入人数:"))
    res = 10 / person_count
    print("每个人分得%d个苹果" % res)


try:
    div_zero()
except ValueError:
    print("值错误")
except ZeroDivisionError:
    print("不能为:0")
except:
    print("未知错误")
else:
    print("没有错误,执行...")
finally:
    print("有没错误,都执行...")

  • raise 主动抛出错误
    异常,是一种天生的错误返回机制,比深层次的 return 方便的多。能人为的快速传递错误消息。


    抛出错误
  • 自定义异常处理
"""
练习05: Python 核心 - 异常处理完整流程
"""


class AttackError(Exception):

    def __init__(self, message, error_line, attack_value, error_no):
        self.message = message
        self.error_line = error_line
        self.attack_value = attack_value
        self.error_no = error_no


class Enemy:

    def __init__(self, name, atk):
        self.name = name
        self.atk = atk

    @property
    def atk(self):
        return self.__atk

    @atk.setter
    def atk(self, value):
        if 0 <= value <= 100:
            self.__atk = value
        else:
            raise AttackError("攻击力范围出错", 27, value, 1001)


try:
    enemy = Enemy('luk', 888)
except AttackError as e:
    print(e.message)
    print(e.error_no)

迭代,可迭代对象

  • 迭代:每一次对过程的重复称为一次“迭代”,每一次迭代的结果会作为下一迭代的初始值。
  • 可迭代对象 iterable
    --- 具有 iter 函数的对象,可以返回迭代器 iterator 对象。
    --- 语法:
    创建:
    class 可迭代对象名称:
    def iter(self):
    return 迭代器
    使用:
    for 变量名 in 可迭代对象
    语句

例如: List 对象都是可迭代对象 Iterable
list01 = [3,44,43,5,45]

  • 迭代原理
    面试题: for 循环原理?
    可以被 for 的条件是什么?

1.获取迭代器 iterator = list01.iter()
2.循环获取下一个元素 iterator.next()
3.遇到异常停止迭代 raise StopIteration
小结:for 循环对象(iterable)必须具有 iter() 方法,并且 iter() 方法必须返回一个迭代器,因为迭代器(iterator) 具有 next() 方法

# 1.获取迭代器
iterator = list01.__iter__()
# 2.循环获取下一个元素
while True:
    try:
          item = iterator.__next__() 
    except StopIteration:
          break  # 3.遇到异常停止迭代
  • 用迭代器原理处理字典循环输出
dict_list = {"apple": 100, "banana": 50, "pear": 80}
iterator = dict_list.__iter__()
while True:
    try:
        key = iterator.__next__()
        num = dict_list[key]
        print("%s的数量为:%d" % (key, num))
    except StopIteration:
        break
  • 迭代器对象 iterator (深入了解原理)
    --- 体会 for 原理的三个步骤是怎样的过程
    --- 学习迭代器 Iterator 是如何工作的
    --- 体会面向对象类与类之间是如何配合工作的
"""
练习16: Python 核心 - 迭代器 Iterator
"""


class Skill:
    def __init__(self):
        pass


class SkillIterator:
    def __init__(self, target):
        self.__target = target
        self.__index = 0

    def __next__(self):
        if self.__index > len(self.__target) - 1:
            raise StopIteration
        temp = self.__target[self.__index]
        self.__index += 1
        return temp


class SkillManager:
    def __init__(self):
        # 私有变量当做容器用
        self.__skills = []

    def add_skill(self, skill):
        # 添加另外一个类对象进容器
        self.__skills.append(skill)

    def __iter__(self):
        # 本来作为一个容器,可迭代,就必须具有迭代方法 __iter__()
        # 可迭代对象必须返回迭代器
        # 可以在一个方法内 New 另外一个类,把自己类的部分数据交给新类去处理,“指鹿为马,指桑骂槐,张冠李戴”
        return SkillIterator(self.__skills)


manager = SkillManager()
manager.add_skill(Skill())
manager.add_skill(Skill())
manager.add_skill(Skill())

# 一用到 for 循环,想到2点,一是具有 __iter__() 方法,具有 __iter__() 就是
# 可迭代对象,可迭代对象一定返回迭代器 (iterator), 迭代器具有迭代功能 __next()__方法
# 最后 for 具有处理异常的能力
for item in manager:
    print(item)

迭代器设计思想
  • 迭代器原理最初版本 Step 1:
"""
练习10: Python 核心 - 迭代器原理
# 定义 MyRange类,实现 for 功能
"""


class RangeIterator:
    def __init__(self, target):
        self.__target = target
        self.__index = 0

    def __next__(self):
        if self.__index > self.__target - 1:
            raise StopIteration
        temp = self.__index
        self.__index += 1
        return temp


class MyRange:
    def __init__(self, end=0):
        self.end = end

    def __iter__(self):
        return RangeIterator(self.end)


my = MyRange(4)
for item in my:
    print(item)
  • yield 代替 XxxIterator 迭代器 Step2
    yield :作用类似 return , 具有返回功能,只是下一次执行 next() 方法时,会继续执行剩余部分代码,直到代码执行完毕。
    另外,具有 yield 关键字的函数,调用不会理解执行,只有等执行 next() 方法是,才会第一次执行。
    yield 就相当于 next(), 相当于迭代器。
"""
练习10: Python 核心 - 迭代器原理 - yield 代替 XxxIterator 迭代器
"""


class MyRange:
    def __init__(self, end=0):
        self.end = end

    def __iter__(self):
        number = 0
        while number < self.end:
            # yield 作用,将这部代码改为迭代器
            yield number
            number += 1


my = MyRange(10)
iterator = my.__iter__()
while True:
    try:
        el = iterator.__next__()
        print(el)
    except StopIteration:
        break

  • 整个迭代类都取代了,换成生成器 Generator:
"""
练习10: Python 核心 - 迭代器原理 - 整个迭代类都取代了
"""


# 生成器 = 可迭代对象 + 迭代器
def my_range(stop_value):
    number = 0
    while number < stop_value:
        # yield 作用,将这部代码改为迭代器
        yield number
        number += 1


my01 = my_range(10)
print(my01)  # <generator object my_range>
for item in my01:
    print(item)

生成器原理

生成器表达式

生成器原理与推导式的不同处
"""
练习17: Python 核心 - 生成器练习
"""
list01 = [3, "6", 68, True, 3.4, "str_222"]


# 生成器函数
def num(target):
    for item in target:
        if type(item) == int:
            yield item


for i in num(list01):
    print(i)  # 3   68

# 生成器表达式
re = (item for item in list01 if type(item) == str)
for it in re:
    print(it)  # “6” “str_222”

# 列表推导式
re = [item for item in list01 if type(item) == float]
print(re)  # [3.4]

函数式编程
  • 函数作为另一个函数的参数,即是把一个函数体注入到另一个函数体内部。

函数式编程思想

"""
练习21: Python 函数式编程思想 1
列表 [43,4,5,5,6,7,87]
需求1:查找列表中的偶数
需求2:查找列表中大于10的数
需求3:查找列表中所有在范围 10 ~ 50 的数
"""


# 封装(分而治之,变则疏之),封装是一种思想,就是找不同。
def condition01(item):
    return item % 2 == 0


def condition02(item):
    return item > 10


def condition03(item):
    return 10 <= item <= 50


# 继承 (隔离变化) condition 就是“变化”的“代表”,是“可继承”的。
def find_list(condition):
    list01 = [43, 4, 5, 5, 6, 7, 87]
    for item in list01:
        # 具体的实现,则是代表着“多态”
        if condition(item):
            yield item


for i in find_list(condition01):
    print(i)

  • 方法传参:如果传递的是123/ABC/True,叫做传递数据
  • 方法传参:如果传递的是函数1/函数2/函数3,叫做传递逻辑
高阶函数

函数的参数或返回值为函数,就叫做“高级函数”

内置高级函数

(1)map(函数,可迭代对象)
(2)filter(函数,可迭代对象)
(3)sorted(可迭代对象,key=函数,reverse=bool)
(4)max(可迭代对象,key=函数)
(5)min(可迭代对象,key=函数)
闭包
作用:能让逻辑连续

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,047评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,807评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,501评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,839评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,951评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,117评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,188评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,929评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,372评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,679评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,837评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,536评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,168评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,886评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,129评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,665评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,739评论 2 351

推荐阅读更多精彩内容