# 作业:
# 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}的形式
# info_list = []
# with open("info.txt","rt",encoding="utf-8") as f:
# for line in f:
# l = line.strip().split(" ")
# info_list.append({"name":l[0],"sex":l[1],"age":l[2],"salary":l[3]})
#print(info_list)
# 2 根据1得到的列表,取出薪资最高的人的信息
#print(max(info_list,key=lambda dic:dic["salary"]))
# 3 根据1得到的列表,取出最年轻的人的信息
#print(min(info_list,key=lambda dic:dic["age"]))
# 4、将names=['egon','alex_sb','wupeiqi','yuanhao']中的名字全部变大写
# info_new=list(map(lambda item:{'name':item['name'].upper(),
# "sex":item["sex"],
# "age":item["age"],
# "salary":item["salary"]},info_list))
# print(list(info_new))
# 5、将names=['egon','alex_sb','wupeiqi','yuanhao']中以sb结尾的名字过滤掉,然后保存剩下的名字长度
#names=['egon','alex_sb','wupeiqi','yuanhao']
# new_list=[]
# for name in names:
# if not name.endswith("sb"):
# new_list.append(len(name))
# print(new_list)
# names = [len(name) for name in names if not name.endswith("sb")]
# print(names)
# names = filter(lambda name:not name.endswith("sb"),names)
# new_name = []
# for item in names:
# new_name.append(len(item))
# print(new_name)
# 6、求文件a.txt中最长的行的长度(长度按字符个数算,需要使用max函数)
# with open("a.txt","rt",encoding="utf-8") as f:
# res = max(len(line) for line in f)
# print(res)
# 7、求文件a.txt中总共包含的字符个数?思考为何在第一次之后的n次sum求和得到的结果为0?(需要使用sum函数)
# with open("a.txt","rt",encoding="utf-8") as f:
# res = sum(len(line) for line in f)
# print(res)
# 8、思考题
#
# with open('a.txt') as f:
# g=(len(line) for line in f)
# print(sum(g)) #为何报错?
#答:变量g指向的是一个生成器,说白了也就是一个迭代器。在迭代器内部并没有存储任何东西,只有在调用
#next方法时,才会去调用生成器按照规则生成一个值。生成器g内部包含的是文件的每一行,而调用生成器g时,文件
#已经关闭,无法读取文件的信息了。所以会抛出一个异常操作关闭的文件异常。
# 9、文件shopping.txt内容如下
#
# mac,20000,3
# lenovo,3000,10
# tesla,1000000,10
# chicken,200,1
# 求总共花了多少钱?
# 打印出所有商品的信息,格式为[{'name':'xxx','price':333,'count':3},...]
text = []
with open("a.txt","rt",encoding='utf-8') as f:
for line in f:
msg = line.strip(" ").split(",")
info_list = {"name":msg[0],"price":msg[1],"count":msg[2]}
text.append(info_list)
total = 0
for item in text:
total += item["price"]*item["count"]
print(total)
print(text)
info = [item for item in text if item["price"] > 10000]
print(info)
info=[]
for item in text:
if item["price"] > 10000:
info.append(item)
print(info)
# 求单价大于10000的商品信息,格式同上
#
# 10、思考:判断下述说法是否正确
# 题目1:
# 1、应该将程序所有功能都扔到一个模块中,然后通过导入模块的方式引用它们 不对
# 2、应该只将程序各部分组件共享的那一部分功能扔到一个模块中,然后通过导入模块的方式引用它们 对
#
# 题目2:
# 运行python文件与导入python文件的区别是什么?
导入python文件是模块,运行是以主文件来运行
# 运行的python文件产生的名称空间何时回收,为什么?
python文件运行完成后回收,因为程序运行过程中使用着各种名称
# 导入的python文件产生的名称空间何时回收,为什么?
主文件运行完成后,因为主程序运行过程一直引用这模块