3.26作业
作业:
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('personal_info',mode='rt',encoding='utf-8') as f:
list1=[{'name':line1[0],'sex':line1[1],'age':line1[2],'salary':line1[3]}
for line1 in[line.strip().split() for line in f]]
print(list1)
方法二:
with open('personal_info',mode='rt',encoding='utf-8') as f:
list1=[{'name':line.strip().split()[0],
'sex':line.strip().split()[1],
'age':line.strip().split()[2],
'salary': line.strip().split()[3]
} for line in f]
print(list1)
方法三:
with open('personal_info',mode='rt',encoding='utf-8') as f:
list1=[]
for line in f:
res=line.strip().split()
dic={'name':res[0],'sex':res[0],'age':res[0],'salary':res[0],}
list.append(dic)
print(list1)
2 根据1得到的列表,取出薪资最高的人的信息
3 根据1得到的列表,取出最年轻的人的信息
4、将names=['egon','alex_sb','wupeiqi','yuanhao']中的名字全部变大写
方法一:
names = ['egon', 'alex_sb', 'wupeiqi', 'yuanhao']
new_names = [name.upper() for name in names]
print(new_names)
方法二:
new_names = map(lambda name: name.upper(), names)
print(list(new_names))
5、将names=['egon','alex_sb','wupeiqi','yuanhao']中以sb结尾的名字过滤掉,然后保存剩下的名字长度
new_names = filter(lambda name: not name.endswith('sb'), names)
len_list = [len(name) for name in list(new_names)]
print(len_list)
6、求文件a.txt中最长的行的长度(长度按字符个数算,需要使用max函数)
a.txt文件内容:
a
ab
abcd
abcde
abcdef
abcdefg
with open('a.txt', mode='rt', encoding='utf-8') as f:
res = max(len(str1.strip()) for str1 in f)
print(res) #7
7、求文件a.txt中总共包含的字符个数?思考为何在第一次之后的n次sum求和得到的结果为0?(需要使用sum函数)
with open('a.txt', mode='rt', encoding='utf-8') as f:
res = sum(len(str1.strip()) for str1 in f)
print(res) #25
res = sum(len(str1.strip()) for str1 in f)
print(res) #0
res = sum(len(str1.strip()) for str1 in f)
print(res) #0
#第一次求和迭代完文件内容,文件指针停留在文件末尾,由于没有重新打开文件, 文件指针一直停留在文件末尾以后的求和sum迭待每次获得的结果都是None,最终求 和为0
with open('a.txt', mode='rt', encoding='utf-8') as f:
res = sum(len(str1.strip()) for str1 in f)
print(res) #25
#重新打开文件指针回到文件的起始位置
8、思考题
with open('a.txt') as f:
g=(len(line) for line in f)
print(sum(g)) #为何报错?
问题:生成一个值,题目中的print处于全局当中,相当于在打印前运行了f.close()将文件已经关闭掉了,打印时文件已经关闭,所以就会报错。
解决办法:将print缩进到打开的文件内
9、文件shopping.txt内容如下
mac,20000,3
lenovo,3000,10
tesla,1000000,10
chicken,200,1
求总共花了多少钱?
with open('shopping.txt', mode='rt', encoding='utf-8') as f:
list1 = []
for line in f:
g, p, n = line.strip().split(',')
list1.append(int(p) * int(n))
print(f'总共花了{sum(list1)}元')
打印出所有商品的信息,格式为[{'name':'xxx','price':333,'count':3},...]
with open('shopping.txt', mode='rt', encoding='utf-8') as f:
list1 = [{'name': line1[0], 'price': int(line1[1]), 'count': int(line1[2])}
for line1 in [line.strip().split(',') for line in f]]
print(list1)
求单价大于10000的商品信息,格式同上
10、思考:判断下述说法是否正确
题目1:
1、应该将程序所有功能都扔到一个模块中,然后通过导入模块的方式引用它们
错
2、应该只将程序各部分组件共享的那一部分功能扔到一个模块中,然后通过导入模块的方式引用它们
对
题目2:
运行python文件与导入python文件的区别是什么?
每次运行py文件,都会执行;而导入py文件只会在第一次导入的时候执行,并产生在内存中申请一个内存空间,之后继续导入py文件不会在执行,只会引用之前申请的内存空间。
运行的python文件产生的名称空间何时回收,为什么?
文件关闭后就会回收,是在全局名称空间进行的,文件关闭就会回收
导入的python文件产生的名称空间何时回收,为什么?