zoukankan      html  css  js  c++  java
  • day 20

    作业:

    # coding:utf-8
    # 作业:
    # 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}的形式
    list1 = []
    with open('a.txt', 'r', encoding='utf-8')as f:
        for line in f:
            name, sex, age, salary = line.strip().split(' ')
            list1.append({'name': name, 'sex': sex, 'age': age, 'salary': salary})
    print(list1)
    
    # 2 根据1得到的列表,取出薪资最高的人的信息
    res = max(list1, key=lambda dic_obj: dic_obj['salary'])
    print(res)  # {'name': 'alex', 'sex': 'male', 'age': '38', 'salary': '30000'}
    
    # 3 根据1得到的列表,取出最年轻的人的信息
    res1 = min(list1, key=lambda dic_obj: dic_obj['age'])
    print(res1)  # {'name': 'egon', 'sex': 'male', 'age': '18', 'salary': '3000'}
    
    # 4、将names=['egon','alex_sb','wupeiqi','yuanhao']中的名字全部变大写
    names = ['egon', 'alex_sb', 'wupeiqi', 'yuanhao']
    res = [name.upper() for name in names]
    print(res) #['EGON', 'ALEX_SB', 'WUPEIQI', 'YUANHAO']
    
    # 5、将names=['egon','alex_sb','wupeiqi','yuanhao']中以sb结尾的名字过滤掉,然后保存剩下的名字长度
    names = ['egon', 'alex_sb', 'wupeiqi', 'yuanhao']
    names2 = [i for i in names if not i.endswith('sb')]
    print(names2) #['egon', 'wupeiqi', 'yuanhao']
    
    # 6、求文件a.txt中最长的行的长度(长度按字符个数算,需要使用max函数)
    with open('a.txt', 'r', encoding='utf-8')as f:
        # for line in f:
        #     res = len(line)
        res = max(f, key= lambda line: len(line))
        print(len(res)) #24
    # 7、求文件a.txt中总共包含的字符个数?思考为何在第一次之后的n次sum求和得到的结果为0?(需要使用sum函数)
    with open('a.txt', 'r', encoding='utf-8')as f:
        sum1 = sum(len(line) for line in f)
        print(sum1) #84
    '''
    # 第一次之后再求和结果为零,因为文件是迭代器对象,取完了就没有了
    '''
    # 8、思考题
    # with open('a.txt','r', encoding='utf-8') as f:
        g=(len(line) for line in f)
        print(g) #<generator object <genexpr> at 0x101e21e08>
    print(sum(g)) #为何报错?
    
    '''
    I/O operation on closed file.
    '''
    # 9、文件shopping.txt内容如下
    # mac,20000,3
    # lenovo,3000,10
    # tesla,1000000,10
    # chicken,200,1
    # 求总共花了多少钱?
    sum1 = 0
    with open('shopping.txt', 'r', encoding='utf-8')as f:
        for line in f:
            name, price, num = line.strip().split(',')
            price = int(price)
            num = int(num)
            sum1 += price * num
    print(sum1) #10090200
    
    # 打印出所有商品的信息,格式为[{'name':'xxx','price':333,'count':3},...]
    list1 = []
    with open('shopping.txt', 'r', encoding='utf-8')as f:
        for line in f:
            name, price, num = line.strip().split(',')
            res = {'name': name, 'price':price, 'count':num}
            list1.append(res)
    print(list1)
    
    # 求单价大于10000的商品信息,格式同上
    res = [dic for dic in list1 if int(dic['price'])>10000]
    print(res) #[{'name': 'mac', 'price': '20000', 'count': '3'}, {'name': 'tesla', 'price': '1000000', 'count': '10'}]
    # 10、思考:判断下述说法是否正确
    #     题目1:
    #     1、应该将程序所有功能都扔到一个模块中,然后通过导入模块的方式引用它们
    '''错误'''
    
    #     2、应该只将程序各部分组件共享的那一部分功能扔到一个模块中,然后通过导入模块的方式引用它们
    '''错误'''
    
    #     题目2:
    #     运行python文件与导入python文件的区别是什么?
    '''
    运行 python文件:多次运行文件时可以多次执行文件内容,运行结束后,名称空间就回收了
    导入文件:只会执行第一次,不会重复执行,导入文件产生名称空间一直存在
            在当前文件名称空间中产生一个名字为模块名,该模块名字指向 该模块的py文件的内存地址
    '''
    
    #     运行的python文件产生的名称空间何时回收,为什么?
    '''
    py文件运行结束就会回收名称空间,
    '''
    #     导入的python文件产生的名称空间何时回收,为什么?
    '''
    导入的 py 文件产生的名称空间只有在 python 解释器关闭才会回收
    '''
    
  • 相关阅读:
    angularjs1.6.4中使用ng-table出现data.slice is not a function的问题
    使用sql语句获取数据库表的信息
    IIS部署web,字体404的问题
    SQL中partition关键字的使用
    asp.net 配置二级域名的共享session,并实现sso单点登录
    同一浏览器中同一JavaWeb程序不共享session方法
    Liquibase的使用
    对象并不一定都是在堆上分配内存的
    阿里面试题,为什么wait()方法要放在同步块中?
    粗浅看 Tomcat系统架构分析
  • 原文地址:https://www.cnblogs.com/xy-han/p/12577467.html
Copyright © 2011-2022 走看看