• day20作业


    # 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('a.txt',mode='r',encoding='utf-8') as f:
        l=[i.strip().split() for i in f]
        res = [{'name':name,'sex':sex,'age':age,'salary':salary} for name,sex,age,salary in l]
    print(res)
    
    # 2 根据1得到的列表,取出薪资最高的人的信息
    res2 = max(res, key=lambda dic:dic['salary'])
    print(res2)
    # 3 根据1得到的列表,取出最年轻的人的信息
    res3 = min(res, key=lambda dic:dic['age'])
    print(res3)
    # 4、将names=['egon','alex_sb','wupeiqi','yuanhao']中的名字全部变大写
    names=['egon','alex_sb','wupeiqi','yuanhao']
    res4 = [name.upper() for name in names]
    print(res4)
    # 5、将names=['egon','alex_sb','wupeiqi','yuanhao']中以sb结尾的名字过滤掉,然后保存剩下的名字长度
    names = ['egon', 'alex_sb', 'wupeiqi', 'yuanhao']
    res5 = [len(name) for name in names if not name.endswith('_sb')]
    print(res5)
    # 6、求文件a.txt中最长的行的长度(长度按字符个数算,需要使用max函数)
    with open('a.txt',mode='r',encoding='utf-8') as f:
        res6 = max(len(line) for line in f)
        print(res6)
    # 7、求文件a.txt中总共包含的字符个数?思考为何在第一次之后的n次sum求和得到的结果为0?(需要使用sum函数)
    with open('a.txt',mode='r',encoding='utf-8') as f:
        l = (len(line) for line in f)
        res7 = sum(l)
        print(res7)
        res8 = sum(l)
        print(res8) # l取出来的是一个生成器  第一次取尽所有值之后就无法取值了 没有值结果就是0
    # 8、思考题
    
    # with open('a.txt') as f:
    #     g=(len(line) for line in f)
    # print(sum(g)) #为何报错?
    sum做加法的时候是在with关闭'a.txt'之后,此时g已经在f.close之后释放了,无法取到g的内部值
    # 9、文件shopping.txt内容如下
    
    # mac,20000,3
    # lenovo,3000,10
    # tesla,1000000,10
    # chicken,200,1
    
    # 求总共花了多少钱?
    with open('shopping.txt',mode='r',encoding='utf-8') as f:
        res = sum(int(line.split(',')[1])*int(line.split(',')[2]) for line in f)
        print(res)
    # 打印出所有商品的信息,格式为[{'name':'xxx','price':333,'count':3},...]
    with open('shopping.txt',mode='r',encoding='utf-8') as f:
        res = [{'name':line.split(',')[0],'price':line.split(',')[1],'count':int(line.split(',')[2])} for line in f]
        print(res)
    # 求单价大于10000的商品信息,格式同上
    with open('shopping.txt',mode='r',encoding='utf-8') as f:
        res = [{'name':line.split(',')[0],'price':line.split(',')[1],'count':int(line.split(',')[2])} for line in f if int(line.split(',')[1])>10000]
        print(res)
    # 10、思考:判断下述说法是否正确
    #     题目1:
    #     1、应该将程序所有功能都扔到一个模块中,然后通过导入模块的方式引用它们
    错误
    #     2、应该只将程序各部分组件共享的那一部分功能扔到一个模块中,然后通过导入模块的方式引用它们
    正确
    #     题目2:
    #     运行python文件与导入python文件的区别是什么?
    1.运行python文件。打开文件——>将内容从硬盘读到内存-->python解释器读取运行;
    2.导入python文件。运行python文件-->产生文件的的名称空间,将文件运行过程中产生的名字都丢到文件的名称空间中-->在当前文件中产生一个名字,该名字指向之前产生的名称空间
    #     运行的python文件产生的名称空间何时回收,为什么?
    程序结束后,运行的python文件产生的名称空间是全局变量名
    #     导入的python文件产生的名称空间何时回收,为什么?
    引用结束之后,导入的python文件产生的名称空间在使用时存在,使用完毕之后名称空间就没用了就被回收
    
  • 相关阅读:
    sql-字符串拼接单,双引号及$
    SQL-SQLServer数据库查询
    SQL-数据库不能以127.0.0.1登录
    Excel-VBA-ActiveX编译错误:用户定义类型未定义
    Excel-VBA中,取:存储过程时,报:对象关闭时,不允许操作!
    JS
    小程序(Wepy)--生成海报图片
    小程序--时间处理(显示几分钟前,,几小时前,,几天前...)
    小程序--wepy省市区三级联动选择
    对于 wepy 不是内部或外部命令 -- 的解决办法
  • 原文地址:https://www.cnblogs.com/yding/p/12576851.html
Copyright © 2020-2023  润新知