作业20200326

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}的形式

2 根据1得到的列表,取出薪资最高的人的信息
3 根据1得到的列表,取出最年轻的人的信息

def get_user_info(file_path, mode='rt', encoding='utf-8'):
    k_list = ['name', 'sex', 'age', 'salary']
    with open(file_path, mode=mode, encoding=encoding) as f:
        return [{k: int(v) if v.isdigit() else v for k, v in \
                 zip(k_list, item.strip().split())} for item in f]



if __name__ == '__main__':

    # q1
    user_list = get_user_info('user_info.txt')
    # print(user_list)

    # q2 薪资最高的人的信息
    salary_max = max(user_list, key=lambda dic: dic.get('salary'))
    # print(one)

    # q3 最年轻的人的信息
    younger = min(user_list, key=lambda dic: dic.get('age'))
    # print(younger)

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

names=['egon','alex_sb','wupeiqi','yuanhao']
new_names = list(map(lambda s: s.upper(), names))
# print(new_names)

5、将names=['egon','alex_sb','wupeiqi','yuanhao']中以sb结尾的名字过滤掉,然后保存剩下的名字长度

names=['egon','alex_sb','wupeiqi','yuanhao']
new_names = list(map(lambda name:len(name), filter(lambda name:not name.endswith('sb'), names)))
print(new_names)

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

def get_max_length(file_path):
    with open(file_path, 'rt', encoding='utf8') as f:
        result = max(f, key=lambda line:len(line.strip()))
        return len(result)

if __name__ == '__main__':
    res = get_max_length('user_info.txt')
    print(res)

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

def get_total_counts(file_path):
    with open(file_path, 'rt', encoding='utf8') as f:
        return sum(map(lambda line:len(line.strip()), f))


if __name__ == '__main__':
    res = get_total_counts('user_info.txt')
    # print(res)
    
# 可能是因为读到文件最后,文件指针跑到了最后,再读就是空

8、思考题

with open('a.txt') as f:
    g=(len(line) for line in f)
print(sum(g)) #为何报错?


# g是一个生成器,它里面保存的迭代取f文件对象的里面每行的数据长度,但是由于with的上下文管理的存在;
# 在with外面,f已经被回收了,无法访问到f, 所以g存在但是g却无法使用。

9、文件shopping.txt内容如下

mac,20000,3
lenovo,3000,10
tesla,1000000,10
chicken,200,1
求总共花了多少钱?

打印出所有商品的信息,格式为[{'name':'xxx','price':333,'count':3},...]

求单价大于10000的商品信息,格式同上

def get_goods_info(file_path):
    k_list = ['name', 'price', 'count']
    with open(file_path, 'rt', encoding='utf8') as f:
        return [{k:v for k, v in zip(k_list, line.strip().split(','))} for line in f]



if __name__ == '__main__':
    goods_info = get_goods_info('shopping.txt')
    # print(goods_info)

    total_expense = sum(map(lambda dic:int(dic.get('price'))*int(dic.get('count')), goods_info))
    # print(total_expense)

    results = list(filter(lambda dic: int(dic.get('price')) > 10000, goods_info))
    # print(results)

10、思考:判断下述说法是否正确

题目1:
	1、应该将程序所有功能都扔到一个模块中,然后通过导入模块的方式引用它们
	2、应该只将程序各部分组件共享的那一部分功能扔到一个模块中,然后通过导入模块的方式引用它们

答:1不对,2对

题目2:
	运行python文件与导入python文件的区别是什么?
	运行的python文件产生的名称空间何时回收,为什么?
	导入的python文件产生的名称空间何时回收,为什么?
	
答:运行python文件和导入python文件的主要区别在名称空间问题上和文件名字上,
	- 文件名问题:
		运行时内置属性__name__等于'__main__',
		导入时 __name__等于 python文件的文件名。
		
	- 名称空间回收问题:
		运行的python文件产生的名称空间在该文件运行结束后就回收;
		导入的python文件产生的名称空间,在它的引用计数为0的时候回收。
posted @ 2020-03-26 17:36  the3times  阅读(26)  评论(0)    收藏  举报