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文件产生的名称空间何时回收,为什么?

posted @ 2020-03-27 00:54  风起千寻  阅读(119)  评论(0编辑  收藏  举报