day 16 - 2 内置函数(二)练习

2020-01-20 15:54:54 浏览数 (1)

内置函数(二)练习

1、用 map 来处理字符串列表,把列表中所有人都变成 sb,比方 alex_sb name=['alex','wupeiqi','yuanhao','nezha']

代码语言:javascript复制
name=['alex','wupeiqi','yuanhao','nezha']
def func(n):
    return n '_sb'

#ret = map(func,name)   #这里的 ret 是一个迭代器,和可迭代的是不同的
#print(list(ret))       #迭代器 for 循环完了 就没有值了 可迭代的每次 for 循环都会生成一个迭代器

#print(list(map(func,name)))

print(list(map(lambda n:n '_sb',name))) #内置函数

2、filter 函数处理数字列表,将列表中所有的偶数筛选出来

代码语言:javascript复制
num = [1,3,5,6,7,8]

def func2(i):
    return i % 2 == 0

print(list(filter(func2,num)))
print(list(filter(lambda i:i % 2 == 0,num)))

#lambda 嵌套 三元运算符
num = [1,3,5,6,7,8]
def func(x):
    if x%2 == 0:
        return True

ret = filter(lambda x:True if x%2 == 0 else False,num) #以及列表推导式
print(list(ret))

3、随意写一个 20 行以上的文件,运行程序,先将内容读到内存中,用列表存储,接收用户输入页码,每页 5 条,仅输出当页的内容

代码语言:javascript复制
with open('E:/py/log/file.txt',encoding='GBK')as f:
    l = f.readlines()
pages,mod = divmod(len(l),5)
if mod != 0:
    pages  =1
page_num = int(input('请输入页码:'))
if page_num < 0 or page_num == 0 or page_num > pages:
    print('请输入1-' str(pages) '的页数')
elif page_num == pages and mod != 0:
    for i in range(mod):
        print(l[(page_num-1)*5 i].strip())
else:
    for i in range(5):
        print(l[(page_num-1)*5 i].strip())

4、如下,每个小字典的 name 对应股票名字,shares 对应多少股,price 对应一股的价格

代码语言:javascript复制
portfolio = [
    {'name': 'IBM', 'shares': 100, 'price': 91.1},
    {'name': 'AAPL', 'shares': 50, 'price': 543.22},
    {'name': 'FB', 'shares': 200, 'price': 21.09},
    {'name': 'HPQ', 'shares': 35, 'price': 31.75},
    {'name': 'YHOO', 'shares': 45, 'price': 16.35},
    {'name': 'ACME', 'shares': 75, 'price': 115.65}
]  
代码语言:javascript复制
#4.1、计算购买每支股票的总价
ret = map(lambda dic:{dic['name']:round(dic['shares']*dic['price'],2)},portfolio)
print(list(ret))


# 4.2、用filter过滤出,单价大于100的股票有哪些
ret = filter(lambda p:p['name'] if p['price']>100 else False,portfolio)
print(list(ret))

ret = filter(lambda dic:True if dic['price'] > 100 else False,portfolio)
print(list(ret))

ret = filter(lambda dic:dic['price'] > 100,portfolio)
print(list(ret))

面试题

1、阅读代码,说出输出结果

代码语言:javascript复制
d = lambda p:p*2
t = lambda p:p*3
x = 2
x = d(x) #x = 4
x = t(x) #x = 12
x = d(x) #x = 24
print(x)

2、现有两个元组 (('a'),('b')),(('c'),('d')),请使用 python 中匿名函数,生成列表 [{'a':'c'},{'b':'d'}]

代码语言:javascript复制
# max min sorted filter map
# 匿名函数 == 内置函数,因为匿名函数往往与内置函数一起使用

ret = zip((('a'),('b')),(('c'),('d')))
res = map(lambda t:{t[0]:t[1]},ret)
print(list(res))

3、以下代码的输出是什么?请给出答案并解释

代码语言:javascript复制
def multipliers():
    return [lambda x:i*x for i in range(4)]
print([m(2) for m in multipliers()])
#结果 [6, 6, 6, 6]

'''
原理:
lambda x: x*i 为内层(嵌)函数,他的命名空间中没有 i 
所以运行时会向外层函数(这儿是列表解析式函数 [ ])的命名空间中请求 i 
而当列表解析式运行时,列表解析式命名空间中的 i 经过循环依次变化为 0-->1-->2-->3 最后固定为 3 ,
所以当 lambda x: x*i 内层函数运行时,去外层函数获取 i 时,每次都只能获取到 3

解决办法:变闭包作用域为局部作用域
给内层函数 lambda x:x*i 增加参数,命名空间中有了用来存储每次的 i,
即:[lambda x, i=i: x*i for i in range(4)] 这样每一次,内部循环生成一个lambda 函数时
都会把 --i-- 作为默认参数传入 lambda 的命名空间
'''
#请修改 multipliers 的定义来产生期望的结果。
def multipliers():
    return (lambda x:i*x for i in range(4))
print([m(2) for m in multipliers()])
#结果 [0, 2, 4, 6]

def multipliers():
    return [lambda x,i=i:i*x for i in range(4)]
print([m(2) for m in multipliers()])

0 人点赞