zoukankan      html  css  js  c++  java
  • 3.26作业

    文件内容如下,标题为:姓名,性别,年纪,薪资
    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:
        res =  [{"name": line.split()[0], "sex": line.split()[1], "age": line.split()[2], "salary": line.split()[3], } for line in f]
        print(res)
    

      

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

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

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

    res = min(lis, key=lambda lis: lis['age'])
    print(res)
    

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

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

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

    names=['egon','alex_sb','wupeiqi','yuanhao']
    names = filter(lambda name:not name.endswith('sb'),names)
    print(list(names))
    

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

    with open('作业(22).txt', mode='rt', encoding='utf-8') as f:
        res = max(f,key=lambda f:len(f))
    print('字数:',len(res),res)
    

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

    with open('作业(22).txt', mode='rt', encoding='utf-8') as f:
        res = sum(len(line) for line in f)
    print(res)
    

      

    思考题
    
    with open('作业(22).txt', mode='rt', encoding='utf-8') as f:
        g=(len(line) for line in f)
    print(sum(g)) # 为何报错?


    g得到的是一个生成器,with管理着上下文,print的时候文件已经关闭,无法进行读取

      

    文件shopping.txt内容如下,求总共花了多少钱?

    with open('shoping.txt',mode='rt',encoding='utf-8') as f:
        res = sum(int(i.strip('
    ').split(',')[1])*int(i.strip('
    ').split(',')[2]) for i in f)
    print(res)
    

      打印出所有商品的信息,格式为

    [{'name':'xxx','price':333,'count':3},...]
    

      

    with open('shoping.txt',mode='rt',encoding='utf-8') as f:
        res = [(lambda line:dict(zip(('name','price','count'),line.strip('
    ').split(','))))(line) for line in f]
    print(res)
    

      

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

    res = filter(lambda price:int(price['price'])>10000,res)
    print(next(res))
    print(next(res))
    

      

    思考:判断下述说法是否正确
        题目1:
        1、应该将程序所有功能都扔到一个模块中,然后通过导入模块的方式引用它们
            这样做会降低原代码的可读性,不方便维护,且可能出现名称空间上的混乱
        2、应该只将程序各部分组件共享的那一部分功能扔到一个模块中,然后通过导入模块的方式引用它们
            1 不正确   2正确
    
        题目2:
        运行python文件与导入python文件的区别是什么?
     运行的话是运行文件,将文件读入内存,从内存获取数据,导入是导入文件,运行文件,产生名称空间
        运行的python文件产生的名称空间何时回收,为什么?
    程序运行结束后进行回收,因为文件一直运行无法回收
        导入的python文件产生的名称空间何时回收,为什么?
    不要有别的文件运用到这个模块,则这个名称空间就不会回收
          
    

      

  • 相关阅读:
    python-IO编程
    DNS解析流程
    python-模块
    HTTP协议
    python-函数式编程
    nmap扫描结果的6种端口状态
    python-高级特性
    python-函数
    python-基础
    上传之路
  • 原文地址:https://www.cnblogs.com/Tornadoes-Destroy-Parking-Lots/p/12577563.html
Copyright © 2011-2022 走看看