# python学习——课后练习

# 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}的形式
# list1=[]
# with open('a.txt',mode='r',encoding='utf8')as f:
#     for k in f:
#         new_dic={}
#         name,sex,age,salary=k.strip().split(' ')
#         new_dic['name']=name
#         new_dic['sex']=sex
#         new_dic['age']=int(age)
#         new_dic['salary']=int(salary)
#         list1.append(new_dic)
#     print(list1)

 



# 2 根据1得到的列表,取出薪资最高的人的信息
# 固定玩法之max
# list2=max(list1,key=lambda dictt:dictt['salary'])   #key=是必须要有的指定取值是k 还是value(比较依据)
# print(list2)

 




# 3 根据1得到的列表,取出最年轻的人的信息
# list2=min(list1,key=lambda dic:dic['age'])
# print(list2)

# 4、将names=['egon','alex_sb','wupeiqi','yuanhao']中的名字全部变大写
# names=['egon','alex_sb','wupeiqi','yuanhao']
# list2=[i.upper() for i in names ]
# print(list2)
#
# 方法2:2.names=['egon','alex_sb','wupeiqi','yuanhao']
# up =map(lambda name:name.upper(),names)
# print(list(up))

 




# 5、将names=['egon','alex_sb','wupeiqi','yuanhao']中以sb结尾的名字过滤掉,然后保存剩下的名字长度
# names=['egon','alex_sb','wupeiqi','yuanhao']
# res=filter(lambda list1:not list1.endswith("_sb"),names)
# print(list(res))

 


# 6、求文件a.txt中最长的行的长度(长度按字符个数算,需要使用max函数)
# with open('a.txt',mode='r',encoding='utf8')as f:
#     res=max(f,key=lambda zi:len(zi))  #f被max取出的数给zi就是一次取出的值通过max比较大小 取出zi最大的值
#     print(res)

 


# # # 7、求文件a.txt中总共包含的字符个数?思考为何在第一次之后的n次sum求和得到的结果为0?(需要使用sum函数)
# with open('a.txt',mode='rt',encoding='utf8')as f:
#     print(sum(len(line) for line in f))
#     print(sum(len(line) for line in f))  # 此时为0
#     # f.seek(0,0)             #从开头再进行取值
#     # # f.seek(0,1)                #从当前位置开始取值
#     f.seek(-9,2)                #从末尾开始前取值  反的向前取    强调:只有0模式可以在t下使用,1、2必须在b模式下用
#                                                                 # 不用编码  读出需要decode()解码
#     print(f.read())

 


# 因为第一次已近迭代完文件里所有的值后指针到最后就无法再取出值来了



# # 8、思考题
# # #
# with open('a.txt') as f:
#     g = (len(line) for line in f)
# print(sum(g))  # 为何报错?
# # 等同于
# f=open('a.txt')
# g = (len(line) for line in f)
# f.close()                     #      提前关闭了
# print(sum(g))
# # 文件关闭取不到值

 


# 9、文件shopping.txt内容如下

# mac,20000,3
# lenovo,3000,10
# tesla,1000000,10
# chicken,200,1

# 求总共花了多少钱?
#
with open('shopping.txt',mode='r',encoding='utf8')as f:
    list=[]
    su=0
    for i in f:
        res=i.strip().split(',')
        list.append(res)
    for i in list:
        res2=i[1].strip()                   #int是不可迭代的
        su+=int(res2)
    print(su)

 


# 10、思考:判断下述说法是否正确
# 题目1:
# 1、应该将程序所有功能都扔到一个模块中,然后通过导入模块的方式引用它们
# 错
# 2、应该只将程序各部分组件共享的那一部分功能扔到一个模块中,然后通过导入模块的方式引用它们
# 对
#
# 题目2:
# 运行python文件与导入python文件的区别是什么?
# 前者是当文件运行,后者是当模块运行
# 运行的python文件产生的名称空间何时回收,为什么?
# 直到运行的程序结束才回收
# 导入的python文件产生的名称空间何时回收,为什么?
# 无人引用时将被回收
posted @ 2021-03-27 14:33  欧阳锦涛  阅读(33)  评论(0)    收藏  举报
TOP 底部