第四周day04作业

# 作业:
# 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'user_info.txt','r',encoding='utf-8') as f:
# line = (line.split() for line in f)
# l = [{'name':name,'sex':sex,'age':age,'salary':salary}for name,sex,age,salary in line]

# print(l)


# 2 根据1得到的列表,取出薪资最高的人的信息
# with open(r'user_info.txt','r',encoding='utf-8') as f:
# line = (line.split() for line in f)
# l = [{'name':name,'sex':sex,'age':age,'salary':salary}for name,sex,age,salary in line]

# print(max(l,key=lambda k:k.get('salary')))

# 3 根据1得到的列表,取出最年轻的人的信息
# with open(r'user_info.txt','r',encoding='utf-8') as f:
# line = (line.split() for line in f)
# l = [{'name':name,'sex':sex,'age':age,'salary':salary}for name,sex,age,salary in line]
# print(min(l,key=lambda k:k.get('age')))

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

# names=['egon','alex_sb','wupeiqi','yuanhao']

# print(list(map(lambda k:k.upper(),names)))


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

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

# with open(r'a.txt','r',encoding='utf-8') as f:
# print(max(len(line) for line in f))

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

# with open(r'a.txt','r',encoding='utf-8') 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)) #为何报错?
# g得到的是生成器,with上下文管理,文件关闭后你又去打印g,g又涉及到操作文件(关闭文件的I/O操作。)


# 9、文件shopping.txt内容如下
#
# mac,20000,3
# lenovo,3000,10
# tesla,1000000,10
# chicken,200,1
# 求总共花了多少钱?
# with open(r'shopping.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'shopping.txt','r',encoding='utf-8') as f:
# line = (line.strip().split(',') for line in f)
# l = list({'name':name,'price':price,'count':count} for name,price,count in line)
# print(l)

# 求单价大于10000的商品信息,格式同上
# with open(r'shopping.txt','r',encoding='utf-8') as f:
# line = (line.strip().split(',') for line in f)
# l = list({'name':name,'price':price,'count':count} for name,price,count in line)
# print(list(filter(lambda k:int(k['price'])>10000,l)))


# 10、思考:判断下述说法是否正确
# 题目1:
# 1、应该将程序所有功能都扔到一个模块中,然后通过导入模块的方式引用它们
# 错误
# 2、应该只将程序各部分组件共享的那一部分功能扔到一个模块中,然后通过导入模块的方式引用它们
# 看情况
# 题目2:
# 运行python文件与导入python文件的区别是什么?
# 运行python文件,打开文件,会发送系统调用,系统将硬盘存放的python文件从硬盘加载到内存,解释器读取运行,运行过程中产生的名字
# 会存放到这个文件的名称空间中去.
# 导入python文件,会执行导入的python文件,运行过程中产生的名字会存放到这个导入的python文件的名称空间中去.
# 运行的python文件产生的名称空间何时回收,为什么?
# 程序运行完毕,名称空间回收
# 导入的python文件产生的名称空间何时回收,为什么?
# 只要别python文件有导入python模块文件, 导入的python文件产生的名称空间就不会关闭

猜你喜欢

转载自www.cnblogs.com/h1227/p/12574799.html