day11_总结

01-函数作为变量

1.函数调用表达式

1)函数调用表达式 - 调用函数的语句
2)普通值能做的事情函数调用表达式都可以做

def func1(x):
    return x**3


def func2(t):
    print('====:', t)
    return func1(2)


8
func1(2)

num = 8
num1 = func1(2)
print(num, num1)

num = 8 * 2
num1 = func1(2) * 2
print(num, num1)

list1 = [8, 10]
list2 = [func1(2), 10]
print(list1, list2)


func2(8)
func2(func1(2))

if 8 % 2 == 0:
    print('偶数')

if func1(2) % 2 == 0:
    print('偶数')


def func3(num1):
    return str(num1)+'abc'


print(func3(100)[-1])
print(func3(213)[2:])
print(func3(123).upper())

2.函数作为变量

1)python中声明函数本质就是声明一个类型是function的变量,函数名就是变量名,变量能做的事情,函数都可以做

1.1)声明一个类型是function的变量, func4是变量

def func4(x):
    print('函数:', x)


a = 10
print(type(a), type(func4))

1.2)一个变量可以给另外一个变量赋值

print('================给变量赋值===============')
b = a
print(b+20)

c = func4
print(c(100))

1.3)给变量重新赋值

a = 'abc'
print(a)

func4 = 321
print(func4*2)
# func4(3)     # TypeError: 'int' object is not callable

1.4)变量作为容器的元素

a = 10
list1 = [a, 10]
print(list1[0]/2)


def func4(x):
    print('函数:', x)


list1 = [func4, func4(20)]
print(list1[1])
print(list1[0](9))   # print(func4(9))


list1 = [
    {'a': 10, 'f': func4},
    100
]
print(list1[0]['f'](100))    # func4(100)


def func5():
    return [1, 2, 3]


list1 = [
    {'a': 10, 'f': func5},
    100
]
print(list1[0]['f']()[1])   # [1, 2, 3][1]

1.5)变量可以作为函数的参数
a.一个函数可以作为另外一个函数的参数
b.如果一个函数的参数也是函数,那么这种函数叫实参高阶函数

def func61(a=0):
    return a*2


# 参数x的类型必须是函数
def func6(x):
    # x = func61
    x()    # x()是调用函数的语句; func61()


func6(func61)


def func7(x):
    return x(10) + 100   # x是函数,并且能够接收一个参数,返回值是数字

3.实参高阶函数: 列表.sort()、sorted()、max(), min()

nums = [1, 78, 9, 78, 67, 100]
print(nums.sort())
print(nums)


nums = (1, 78, 9, 78, 67, 100)
print(sorted(nums))
print(nums)

3.1)sort和sorted
a.这两个函数是实参高阶函数,里面有个参数key要求传一个函数
b.key参数对应的函数是用来决定排序规则: 函数需要一个参数和一个返回值, 它的参数代表需要排序的序列的元素,返回值是比较对象
c.数字列表, 排序规则发生改变: 按照数字的个位数从小到大排序

nums = [21, 69, 367, 78, 478, 5100]

# key对应的函数1: 按照元素本身大小进行排序
# [21, 69, 367, 78, 478, 5100]
def func(item):
    return item


# key对应的函数2: 按照 元素%10 的值的大小进行排序
def func1(item):
    return item % 10


# key对应的函数3:按照元素的最高位的值进行从小到大排序
def func2(item):
    return int(str(item)[0])


nums.sort(key=func2)    # 按照元素本身大小进行排序
print(nums)

练习: 给一个数字列表,按照各位数的和的大小从下到大排序

nums = [12, 67, 18, 90, 890, 123, 99]    # [3, 13, 9, 9, 17, 6, 18]
# nums = [12, 123, 18, 90, 67, 890, 99]


def func3(item):
    sum1 = 0
    for ch in str(item):
        sum1 += int(ch)
    return sum1


nums.sort(key=func3)
print(nums)

练习:

all_students = [
    {'name': '小明1', 'age': 23, 'score': 89, 'id': 'stu001'},
    {'name': '小明2', 'age': 30, 'score': 70, 'id': 'stu029'},
    {'name': '小明3', 'age': 18, 'score': 99, 'id': 'stu010'},
    {'name': '小明4', 'age': 21, 'score': 40, 'id': 'stu004'},
]


def func4(item):
    return item['score']


all_students.sort(key=func4, reverse=True)
print(all_students)

nums = [12, 39, 56]
print(max(nums, key=lambda item: item % 10))


print(max(all_students, key=lambda item: item['score']))

print(max([1, 78, 9]))
print(max({90, 9, 100, 89}))
# print(max(all_students))   # TypeError: '>' not supported between instances of 'dict' and 'dict'
# print(max(all_students, key=10))   # TypeError: 'int' object is not callable
print(max(all_students, key=lambda x: x['score']))

实现原理(了解!)

def yt_max(seq, key=None):
    seq = list(seq)
    if not key:
        max1 = seq[0]
        for x in seq[1:]:
            if x > max1:
                max1 = x
        return max1

    # key存在
    max1 = seq[0]
    for x in seq[1:]:
        if key(x) > key(max1):
            max1 = x
    return max1


print(yt_max([1, 78, 9]))
print(yt_max({90, 9, 100, 89}))
# print(yt_max(all_students))    # TypeError: '>' not supported between instances of 'dict' and 'dict'
# print(yt_max(all_students, key=10))   # TypeError: 'int' object is not callable
print(yt_max(all_students, key=lambda x: x['score']))

4.变量作为函数的返回值

4.1)一个函数的返回值如果也是一个函数,那么这个函数就是返回值高阶函数

# func1是返回值高阶函数,因为它的返回值是一个函数
def func1():
    def func11():
        return 10

    return func11


f = func1()
print(f())   # print(func11())  print(10)
f()


def operation(symbol):
    if symbol == '+':
        def sum(*num):
            sum1= 0
            for x in num:
                sum1 += x
            return sum1
        return sum
    elif symbol == '-':
        def differ(*num):
            sum1 = num[0]
            for x in num[1:]:
                sum1 -= x
            return sum1
        return differ


print(operation('+')(1, 2, 3, 9))
print(operation('-')(1, 2, 4))

5.****装饰器! = 实参高阶函数+返回值高阶函数+函数+糖语法

02-迭代器

1.什么是迭代器(iter)

a.迭代器是容器型数据类型(序列), 可变(不支持增删改),有序(不支持下标操作)
b.保存在迭代器中的元素,只能取,并且取出后迭代器中就不再保存,也不可以再往迭代器中添加元素

c.迭代器没有对应的格式的数据, 迭代器只能是通过将其他的序列转换成迭代器,或者是生成器

iter1 = iter([10, 20, 30])
print(iter1)

iter2 = iter('hello')
print(iter2)

2.获取迭代器中的元素

a.不管用什么样的方式去获取迭代器中的元素, 获取一个就会少一个

  1. 获取单个元素: next(迭代器) - 获取迭代器顶部的元素(最上层/第一个元素)
print(next(iter2))    # h
print(next(iter2))    # e
print(next(iter2))    # l
print(next(iter2))    # l
print(next(iter2))    # o
# print(next(iter2))  # 报错, StopIteration
  1. 遍历
iter2 = iter('abc123')
print(next(iter2))    # a
print(next(iter2))    # b
for x in iter2:
    print('===:', x)
# print(next(iter2))    # StopIteration

03-生成器

1.什么是生成器

a.生成器就是迭代器 - 获取元素和迭代器一样(只能一个一个的取,取一个少一个)
b.调用函数体中有yield关键字的函数,就可以得到一个生成器

2.yield

a.yield只能出现在函数体中
b.调用有yield关键字的函数, 不会执行函数体,也不会获取返回值。而是得到一个生成器

def func1():
    print('我是一个函数')
    return 100
    yield


print(func1())

3.生成器怎么产生数据

a.看一个生成器能够产生几个数据,看执行完生成器对应的函数会遇到几次yield;yield后面的值就是生成器能产生数据

def func2():
    for x in range(10):
        yield x


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

4.生成器生成数据的原理

a.生成器不会同时将所有的元素保存起来, 而是需要数据的时候临时产生数据。

b.获取生成器元素的时候,就去执行生成器对应的函数的函数体,从前往后执行,
直到遇到yield为止, 并且将yield后面的值作为结果,同时保存结束位置;
下次获取下一个元素的时候,接着上次结束的位置往后执行,直到遇到下一个yield;
以此类推...
如果执行到函数结束都没有遇到yield, next函数会报StopIteration错误

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


def func3():
    print('start')
    print('======第一个数据=====')
    yield 1
    print('======第二个数据======')
    yield 2
    print('======第三个数据=====')
    yield 3
    print('end')


gen2 = func3()
print(next(gen2))
print('开始取第2个数据:')
print(next(gen2))
print('开始取第3个数据:')
print(next(gen2))
# print(next(gen2))     # StopIteration


def func2():
    print('===============')
    yield
    print('+++++++++++++++')
    yield


def func3():
    print('1111111111111111')
    yield
    print('2222222222222222')
    yield


gen3 = func2()
gen4 = func3()

next(gen3)
next(gen4)
next(gen3)
next(gen4)

写一个产生学号的生成器

def creat_id():
    num = 1
    while True:
        yield 'stu'+str(num)
        num += 1


nums = creat_id()
print(next(nums))
print(next(nums))

for _ in range(100):
    print('===:', next(nums))

print(next(nums))


def func4():

    yield 1
    return 10
    yield 2
    yield 3


gen5 = func4()
print(next(gen5))
# print(next(gen5))   # StopIteration: 10

04-生成式

1.什么是生成式

a.生成式本质就是生成器

1)语法1
(表达式 for 变量 in 序列) - 创建一个生成器

展开成生成器:
def func1():
for 变量 in 序列:
yield 表达式

[表达式 for 变量 in 序列] - 将声称是对应的生生成器转换成列表

2)语法2
(表达式 for 变量 in 序列 if 条件语句) - 创建一个生成器
展开成生成器:
def func1():
  for 变量 in 序列:
     if 条件语句:
       yield 表达式

gen1 = (x*2 for x in range(10))
print(next(gen1))
print(next(gen1))

list1 = list(gen1)
print(list1)        #[4,6,8,10···18]

# print(next(gen1))         # StopIteration
def func():
    for x in range(10):
    yield  x*2
gen1 = func()


list2 = [x*x for x in range(1,10)]
print(list2)        # [1,4,9,16,25,36,49,64,81]

list3 = list((x*x) for x in range(1,10))
print(list3)        # [1,4,9,16,25,36,49,64,81]

dict1 = dict((x,x*2)for x in range(5))
# (0,0),(1,2),(2,4),(3,6),(4,8)
print(dict1)    # {(0,0),(1,2),(2,4),(3,6),(4,8)}

list4 = ["stu"+str(x) for x in range(10) if x % 2 ]
print(list4)    #["stu1","stu3","stu5","stu7","stu9"]

list5 = ["%d*2=%d" % (x,x*2) for x in range(5)]
print(list5)

05-模块的使用

a.在实际开发的时候,一个项目会分为多个模块

1.什么是模块:一个py文件就是一个模块

2.多模块怎么协作: 导入模块

  1. import 模块名 - 在当前模块中导入指定模块,导入后可以使用指定模块中所有的全局变量
    以'模块名.变量'的方式去使用

  2. from 模块名 import 全局变量1,全局变量2,...
    - 导入指定模块中指定的全局变量; 被导入的全局变量在当前模块中直接使用

3)重命名
import 模块名 as 新模块名 - 模块重命名,通过新模块名去使用模块
from 模块名 import 变量1 as 新变量1, 变量2 as 新变量2,...
变量重命名,通过新变量去使用变量

  1. 通配符
    from 模块名 import * - 导入模块中所有的全局变量,使用的时候直接用

导入方式一:

 import login

login.login()
print(login.num)
print(login.text)
print(login.x)

导入方式二:

from login import login, num
login()
print(num)
# # print(text)     # NameError: name 'text' is not defined
# # print(login.text)   # AttributeError: 'function' object has no attribute 'text'

模块重命名

import login as loginModule
login = True
# print(login.num)   # AttributeError: 'bool' object has no attribute 'num'
print(loginModule.num)

# from login import login, num as lg_num
# num = 123
# print(num, lg_num)   # 123 100
#
# login()

通配符

from login import *
print(num, x, text)
login()

3.导入模块的原理

a.当执行导入模块的代码的时候,实质会执行被导入的模块对应的py文件

print('06模块中的name:', __name__)

# import login
from login import num

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

推荐阅读更多精彩内容

  • 1.函数调用表达式:调用函数的语句 普通值能做的事情函数调用表达式都能做 2.函数作为变量 !python中声明函...
    itachhh阅读 221评论 0 0
  • 一.函数作为变量 1.函数调用表达式 函数调用表达式 - 调用函数的语句普通值能做的事,函数调用表达式都可以做 2...
    SheeranED阅读 149评论 0 0
  • 递归函数 1.什么是递归?在函数中调用本身的函数被称为递归函数 2.递归的作用:循环可以做的事情递归函数都可以做,...
    xue_y阅读 138评论 0 0
  • 文件的操作 1.模块的使用 1.导入模块Python中一个py文件就是一个模块,可以通过import或者form-...
    hfudhu阅读 207评论 0 0
  • 01.recode 1.容器类数据类型 a.列表:可变,有序b.元祖:x, y = 12, 100; x, *n...
    Gary134阅读 211评论 0 0