• day16 内置函数作业


    3.用map来处理字符串列表,把列表中所有人都变成sb,比方alex_sb
    name=['alex','wupeiqi','yuanhao','nezha']
    #方法1用内置函数map
    def func(abc):
    return abc+'_sb'
    ret = map(func,name) #ret是生成器
    for i in ret:
    print(i)
    #方法2用匿名函数
    ret = map(lambda abc:abc+'_sb',name)
    print(list(ret))
    # 4.用filter函数处理数字列表,将列表中所有的偶数筛选出来
    #方法1:使用内置函数filter
    num = [1,3,5,6,7,8]
    def Choose(s):
    return s % 2 == 0
    ret = filter(Choose,num)
    print(list(ret)) #使用强转和for循环效果是一样的
    for i in ret:
    print(i)
    #方法2:使用lambda函数
    num = [1,3,5,6,7,8]
    def Choice(s):
    return s % 2 == 0
    res = filter(lambda s:s % 2 == 0,num)
    print(list(res))

    '''5.随意写一个20行以上的文件
    运行程序,先将内容读到内存中,用列表存储。
    接收用户输入页码,每页5条,仅输出当页的内容'''
    with open("test",encoding="utf-8") as f:
    l = f.readlines()
    page_num = int(input("输入页码:").strip())
    pages,mod = divmod(len(l),5) #求有多少页,有没有剩余的行数
    if mod: # 如果有剩余的行数,那么页数加一
    pages += 1 # 一共有多少页
    if page_num > pages or page_num <= 0: #用户输入的页数大于总数或者小于等于0
    print('输入有误')
    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()) #输出5行


    # 6.如下,每个小字典的name对应股票名字,shares对应多少股,price对应股票的价格
    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}
    ]
    # 6.1.计算购买每支股票的总价
    ret = map(lambda dic : {dic['name']:round(dic['shares']*dic['price'],2)},portfolio)
    print(list(ret))
    ret = map(lambda dic : {dic['name']:dic['shares']*dic['price']},portfolio)
    print(list(ret))

    #[{'IBM': 9110.0}, {'AAPL': 27161.0}, {'FB': 4218.0}, {'HPQ': 1111.25}, {'YHOO': 735.75}, {'ACME': 8673.75}]
    # 6.2.用filter过滤出,单价大于100的股票有哪些
    #方法1
    res = filter(lambda dic:True if dic['price'] > 100 else False,portfolio)
    print(list(res))
    #方法2
    ret = filter(lambda dic:dic['price'] > 100,portfolio)
    print(list(ret))
    #[{'name': 'AAPL', 'shares': 50, 'price': 543.22}, {'name': 'ACME', 'shares': 75, 'price': 115.65}]
  • 相关阅读:
    VC内存泄露检查工具:Visual Leak Detector
    ArcGIS Server 开发系列(五)自定义 Toolbar 工具2 (转载于Flyingis)
    Arcgis Server系列 安装与配置
    ArcGIS Server 开发系列(四)ArcGIS Server data sources 开发 (转载于Flyingis)
    ArcGIS Server 开发系列(五)自定义 Toolbar 工具 (转载于Flyingis)
    ArcMap的地图缓存MapCache
    C# 字符串 合并时 + 和 stringbulilder 的区别是什么?
    ArcGIS Server 体系结构
    ArcGIS Server 开发系列(三)漫游 Graphics data sources (转载于Flyingis)
    ArcGIS Server .Net Web ADF体系结构
  • 原文地址:https://www.cnblogs.com/Murraya/p/10888273.html
Copyright © 2020-2023  润新知