Day11-python生成器和模块

一、生成器

1.什么是生成器

生成器就是迭代器中的一种; 生成器作为容器它保存的不是数据,而是产生数据的算法

2.怎么创建生成器

调用带有yield关键字的函数,就可以得到一个生成器
注意: 函数中只要有yield不管遇不遇得到,调用这个函数都不会执行函数体,并且得到的是一个生成器对象

def func1():
    print('=====')
    print('+++++')
    return 100
    if False:
        yield


re = func1()   # 这儿的re就是生成器
print(re)   # <generator object func1 at 0x10830aeb8>

3.生成器怎么产生数据(怎么确定生成器中的元素)

一个生成器能够产生多少个数据和哪些数据,看执行完生成器关联的函数的函数体会遇到几次yield;
遇到几次yield生成器就可以产生多个数据;每次遇到yield,yield后面的数据就是对应的元素

def func2():
    # print('=====')
    yield 10
    # print('++++')
    yield 100
    yield 1000


gen1 = func2()
for x in gen1:
    print('x:', x)

# print(next(gen1))     # StopIteration

4. 生成器产生数据的规律

生成器怎么获取元素:

1). 获取第一个元素的时候从函数的第一条语句开始执行,执行到第一个yield为止,并且将yield后面的值作为当前获取到的元素;获取下一个元素的时候接着上次结束的往后执行,直到遇到下一个yield为止,并且将yield后面的值作为当前获取到的元素;以此类推...
2). 如果从执行位置开始到函数结束没有遇到yield就会报StopIteration的错误

def func2():
    print('==========')
    yield 1
    print('++++++++++')
    yield 10
    print('**********')
    yield 100
    print('!!!!!!!!!!!')


gen2 = func2()
print(gen2)    # <generator object func2 at 0x105f01468>
print(next(gen2))
print('=====获取第一个值结束====')
print(next(gen2))
print('=====获取第二个值结束====')
print(next(gen2))
print('=====获取第四个值结束====')
# print(next(gen2))    # StopIteration


def func3(n):
    for _ in range(n):
        yield 100


gen3 = func3(4)
next(gen3)
for x in gen3:
    print('x:', x)


def func4(n):
    for x in range(1, n+1):
        yield x*x


gen4 = func4(4)
print(next(gen4))
print(next(gen4))     # 4
for m in gen4:
    print('m:', m)

print(next(func4(4)))   # 1
print(next(func4(4)))   # 1

练习:写一个生成器,能够产生一班所有学生的学号,班级人数自己定; 前缀自己定

# 234 -> py001, py023, py122
# 59  -> h501, h534
def create_study_id(pre: str, count: int):
    length = len(str(count))
    for num in range(1, count+1):
        yield pre+str(num).zfill(length)


nums = create_study_id('python', 30)
print(next(nums))
for num in nums:
    print(num)

二、生成式

1.什么是生成式

生成式就是生成器;只是写法上更简洁,只有一行代码

1). 语法一:

生成器 = (表达式 for 变量 in 序列)

相当于普通生成器:
def 函数名():
    for 变量 in 序列:
        yield 表达式
生成器 = 函数名()

2)语法二:

生成器 = (表达式 for 变量 in 序列 if 条件语句)

def 函数名():
      for 变量 in 序列:
         if 条件语句:
            yield 表达式
生成器 = 函数名()

3)语法三

生成器 = (表达式 for 变量1 in 序列1 for 变量2 in 序列2)

def 函数名():
    for 变量1 in 序列1:
       for 变量2 in 序列2:
            yield 表达式
生成器 = 函数名()
"""

2.列表生成式

将上面生成式语法中所有的()变成[],结果就会由原来的生成器,变成列表

生成器 = (表达式 for 变量 in 序列)
[表达式 for 变量 in 序列] == list(生成器)

写一个生成器:产生数字1~10

# 方法一:
def create_num():
    for num in range(1, 11):
        yield num


gen1 = create_num()

# 方法二:
gen2 = (num for num in range(1, 11))
print(gen2)   # <generator object <genexpr> at 0x10e3c0468>
# print(next(gen2))
# print(next(gen2))

print([num for num in range(1, 11)], list(gen2))


gen3 = ('str%s' % x for x in range(5))
print(next(gen3))

def func2():
    for x in range(5):
        yield 'str%s' % x


gen4 = (x for x in range(0, 10) if x % 2)
# gen4中的元素:  1,3,5,7,9
for num in gen4:
    print('num:', num)

三、导入模块的原理

1.导入模块的原理

"""
不管是通过import直接导入模块,还是通过from-import去导入模块的变量。当代码执行到导入模块的语句
的时候,系统会自动进入被导入的模块中,执行这个模块中所有的代码;执行完后再回到当前模块接着往后执行
"""

2.阻止导入

"""
如果将模块中的代码写入if name == 'main'这个if语句中, 那么这个if语句代码在被导入的时候不会执行。直接运行当前模块的时候会执行

阻止的原理:
在创建模块的时候,系统会自动给这个模块添加属性: name, 用来保存当前模块的名字;
name属性的值默认是当前文件的文件名; 当直接运行当前模块的时候,这个模块的name属性值会变成'main', 运算完成后又变回文件名。

"""
print('06的模块名:', name)

print('========================')

import test1

import test2

四、包的使用

1.什么是包

"""
包含init.py文件的文件夹; 包是用来管理模块

"""

=========1. 导入指定包中指定模块: 使用模块的时候 - 包.模块==============

# import game.display
# print(game.display.bg)   # 背景
# game.display.create_window(100, 200)   # 创建窗口:100x200

===========2. 导入指定包中指定模块,对'包.模块'进行重命名==============

# import game.display as display
# print(display.bg)  # 背景
# display.create_window(10, 8)    # 创建窗口:10x8

============3. 导入指定包中指定模块: 使用模块的时候 - 模块==============

# from game import display, font
# print(display.bg)
# display.create_window(1, 2)

================4.直接导入包中指定模块中的指定的变量=======================

# from game.display import create_window, bg
# print(bg)
# create_window(3, 4)

# import game
# print(game.display.bg)
# print(game.bg)

from game import bg, func1
print(bg)
func1()

五、hashlib模块

1.什么是hashlib

"""
hashlib是python提供的用来通过哈希算法进行加密(产生摘要)的一个库
哈希又叫离散算法,主要包含md5、sha两类算法
"""

2.哈希算法加密特点

"""
1)加密后的摘要(密文)是不可逆的
2)相同的数据通过同一种算法产生的摘要是一样的
3)不同长度的数据通过同一种算法产生摘要的长度是一样的
"""

3.怎么产生数据的摘要

"""
1)创建hashlib的对象: hashlib.算法名()
2)添加需要产生摘要的数据: 哈希对象.update(数据)

注意: 数据必须是二进制数据

3)生成摘要(密文): 哈希对象.hexdigest()
"""

# 1.创建哈希对象
hash = hashlib.md5()

# 2.添加数据
# pw = '123456'+'张三'
# hash.update(pw.encode())
hash.update('123456'.encode())
hash.update('张三'.encode())

# 3.生成摘要(密文)
result = hash.hexdigest()
print(result)   # e10adc3949ba59abbe56e057f20f883e


====================补充: 字符串和二进制的相互转换================

python中的bytes就是二进制对应的数据类型

1.字符串转二进制

1). bytes(字符串, encoding='utf-8')
2). 字符串.encode()

二进制转字符串

1). str(二进制, encoding='utf-8')
2). 二进制.decode(encoding='utf-8')

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

推荐阅读更多精彩内容

  • 一、生成器 1.什么是生成器生成器就是迭代器中的一种; 生成器作为容器它保存的不是数据,而是产生数据的算法2.怎么...
    孤独的死小孩阅读 470评论 0 0
  • 生成器 1.什么是生成器 生成器就是迭代器中的一种; 生成器作为容器它保存的不是数据,而是产生数据的算法 2.怎么...
    KIKIu阅读 248评论 0 0
  • 今天试了一下素描 真的是好多年不动笔 都不会画了 回归零基础开始学习吧
    Angel可可阅读 219评论 0 0
  • 或许啊 那些曾经离开我们的人正在以不同的方式回到我们身边 所以 希望你的性格随遇而安半点儿不贪婪,希望雨舒云展! ...
    柒Dream阅读 357评论 0 2
  • 梁启超是清末戊戌变法的领袖之一,是近代著名的思想家、政治家和学术大家。与此同时,他还是一位“超级老爸”。梁启超一共...
    耿科阅读 537评论 0 2