注:函数中只要有yield,不管会不会遇到(执行),则调用该函数,函数体都不会执行,并且得到一个生成器
# 例:
def func3():
print('======')
yield 1
print('++++++')
yield 10
print('******')
yield 100
gen2 = func3()
print(next(gen2))
print(next(gen2))
print(next(gen2))
print(next(gen2)) # 元素取完后报错
# 练习:写一个生成器能产生一个班所有学生的学号
def students_num(n):
length = len(str(n))
for num in range(1,n+1):
yield str(num).zfill(length)
nums = students_num(50)
for num1 in nums:
print(num1)
"""
1)语法①:
生成器 = (表达式 for 变量 in 序列)
展开:
def 函数名():
for 变量 in 序列:
yield 表达式
生成器 = 函数名()
语法②:
生成器 = (表达式 for 变量 in 序列 if 条件语句)
展开:
def 函数名():
for 变量 in 序列:
if 条件语句:
yield 表达式
生成器 = 函数名()
语法③:
生成器 = (表达式 for 变量1 in 序列1 for 变量2 in 序列2)
展开:
def 函数名():
for 变量1 in 序列1:
for 变量2 in 序列2:
yield 表达式
生成器 = 函数名()
"""
# 例:
gen1 = (num for num in range(1, 11))
gen4 = (x for x in range(10) if x % 2)
若要使用另外一个模块的内容,需要在当前模块中导入相应的模块
①:import 模块名
- 导入后可以使用被导入模块的所有全局变量
- 以 ‘模块名.变量名‘ 的方式使用相应模块
②:from 模块名 import 变量名1, 变量名2,...
- 导入后可以使用import后指定的变量
- 使用时直接使用
③:from 模块名 import *
- 导入后可以使用被导入模块的所有全局变量
- 使用时直接使用
也可以通过这种方式对模块中的变量进行重命名
阻止原理:模块在创建的时候,系统会为模块添加 __name__ 属性,用来保存该模块的名字; __name__ 默认是该文件的文件名,当直接运行该模块时, __name__ 会变成 __main__,此时if语句成立,执行后面的代码
包是包含 __init__.py** 文件的文件夹**
①:import 包.模块 (可用as重命名)
包.模块.调用的代码名
②:from 包 import 模块1, 模块2, ...
模块.调用的代码名
③:from 包.模块 import 调用的代码名
④:from 包.模块 import 变量
哈希算法又叫离散算法,主要包含MD5,sha两类算法
1).加密后的的密文(摘要)是不可逆的
2).相同的数据通过通过相同的算法加密后的密文是相同的
3).不同长度的数据通过相同的算法加密后的密文长度是相同的
hash = hashlib.md5()
pw = '123456'
hash.update(pw.encode())
result = hash.hexdigest()
print(result)
>>>>>>> 知识扩展
bytes是二进制的数据类型
1.字符串转二进制
①:bytes(字符串, encoding=‘utf-8‘)
②:字符串.encode()
2.二进制转字符串
①:str(二进制,encoding=‘utf-8‘)
②:二进制.decode(encoding=‘utf-8‘)
原文:https://www.cnblogs.com/anjhon/p/11892363.html