• python第20天作业


    作业:

    1、文件内容如下,标题为:姓名,性别,年纪,薪资

    egon male 18 3000

    alex male 38 30000

    wupeiqi female 28 20000

    yuanhao female 28 10000

    #

    要求:

    从文件中取出每一条记录放入列表中,

    列表的每个元素都是{'name':'egon','sex':'male','age':18,'salary':3000}的形式

    # 方法一
    with open(r'db.txt','r',encoding='utf-8')as f:
        l = []
        new_l = [i.strip().split(' ') for i in f]
        for x in new_l:
            value = [value for value in x]
            keys = ['name', 'sex', 'age','salary']
            dic = {k:v for k,v in zip(keys,value)}
            l.append(dic)
    
    # 方法二
    with open(r'db.txt','r',encoding='utf-8')as f:
        l = ['name','sex','age','salary']
        user_list = [dict(zip(l,line.strip().split())) for line in f]
        print(user_list)
    
    # 方法三
    with open(r'db.txt', 'r', encoding='utf-8')as f:
        res =  [{"name": line.split()[0], "sex": line.split()[1], "age": line.split()[2], "salary": line.split()[3], } for line in f]
        print(res)
    

    2 根据1得到的列表,取出薪资最高的人的信息

    res =max(l,key=lambda k:k['salary'])
    print(res)
    

    3 根据1得到的列表,取出最年轻的人的信息

    res =min(l,key=lambda k:k.get('age'))
    print(res)
    

    4、将names=['egon','alex_sb','wupeiqi','yuanhao']中的名字全部变大写

    names=['egon','alex_sb','wupeiqi','yuanhao']
    res = map(lambda name:name.upper(),names)
    print(list(res))
    

    5、将names=['egon','alex_sb','wupeiqi','yuanhao']中以sb结尾的名字过滤掉,然后保存剩下的名字长度

    names=['egon','alex_sb','wupeiqi','yuanhao']
    res = filter(lambda name:not name.endswith('sb'),names)
    res = [len(i) for i in res]
    print(res)
    

    6、求文件a.txt中最长的行的长度(长度按字符个数算,需要使用max函数)

    with open("a.txt",'rb')as f:
        res=max(f,key=lambda k:len(k))
        print(res)
    

    7、求文件a.txt中总共包含的字符个数?思考为何在第一次之后的n次sum求和得到的结果为0?(需要使用sum函数)

    from functools import reduce
    with open('a.txt', 'r',)as f:
        print(sum(len(line) for line in f)
    

    8、思考题

    with open('a.txt') as f:
    
       g=(len(line) for line in f)
    
    print(sum(g)) #为何报错?
    

    因为文件在print之前已经关闭了,调用g需要文件是开着的

    9、文件shopping.txt内容如下

    mac,20000,3

    lenovo,3000,10

    tesla,1000000,10

    chicken,200,1

    求总共花了多少钱?

    with open(r'shoping.txt', 'r', encoding='utf-8') as f:
        info = [line.strip().split(',') for line in f]
        res = sum(int(price)*int(count) for name, price, count in info)
        print(res)
    

    打印出所有商品的信息,格式为[{'name':'xxx','price':333,'count':3},...]

    with open(r'shoping.txt', 'r', encoding='utf-8')as f:
        res = [{"name": line.strip().split(',')[0], "price": line.strip().split(',')[1], "count": line.strip().split(',')[2]} for line in f]
        print(res)
    

    求单价大于10000的商品信息,格式同上

    with open(r'shoping.txt', 'r', encoding='utf-8')as f:
        res = [{"name": line.strip().split(',')[0], "price": line.strip().split(',')[1], "count": line.strip().split(',')[2]} for line in f]
    info_res = filter(lambda k:int(k.get('price'))>10000,res)
    print(list(info_res))
    

    10、思考:判断下述说法是否正确

    题目1:

    1、应该将程序所有功能都扔到一个模块中,然后通过导入模块的方式引用它们 不正确

    2、应该只将程序各部分组件共享的那一部分功能扔到一个模块中,然后通过导入模块的方式引用它们 正确

    题目2:

    运行python文件与导入python文件的区别是什么?

    运行的话是运行文件,将文件读入内存,从内存获取数据

    导入是导入文件,运行文件,产生名称空间

    运行的python文件产生的名称空间何时回收,为什么?

    程序运行结束后进行回收,因为文件一直运行无法回收

    导入的python文件产生的名称空间何时回收,为什么?

    不要有别的文件运用到这个模块,则这个名称空间就不会回收

  • 相关阅读:
    SpringMVC
    MyBatis 与 Spring 的完美整合方法
    持久层之 MyBatis: 第三篇 :缓存 And 高级查询
    持久层之 MyBatis: 第二篇 :动态SQL And多表查询
    C语言实现简单epoll服务器(二)
    C语言简单实现epoll服务器(一)
    shell编程题(十九)
    shell编程题(十七)
    shell编程题(十六)
    shell编程题(十三)
  • 原文地址:https://www.cnblogs.com/Lance-WJ/p/12576988.html
Copyright © 2020-2023  润新知