1. 文件a.txt内容:每一行内容分别为商品名字,价钱,个数。

apple 10 3

tesla 100000 1

mac 3000 2

lenovo 30000 3

chicken 10 3

通过代码,将其构建成这种数据类型:

[{'name':'apple','price':10,'amount':3},

{'name':'tesla','price':1000000,'amount':1}......] 并计算出总价钱。

答:

li = []
with open('a.txt', encoding='utf-8', mode='r') as f1:
for i in f1:
l2 = i.strip().split()
dic = {'name':l2[0], 'price':l2[1], 'amount':l2[2]}
li.append(dic)
print(li)
sum = 0
for j in li:
sum = sum + int(j['price']) * int(j['amount'])
print(sum) 优化扩展代码如下:
name_list = ['name', 'price', 'amount']
li = []
with open('a.txt', encoding='utf-8', mode='r') as f1:
for i in f1:
l2 = i.strip().split()
# dic = {}
# for j in range(len(l2)):
# dic[name_list[j]] = l2[j]
dic = dict(zip(name_list, l2)) # 前面三句可以优化成这一句,易读性也更强
li.append(dic)
print(li)
sum = 0
for k in li:
sum = sum + int(k['price']) * int(k['amount'])
print(sum)

2,有如下文件:

-------
alex是老男孩python发起人,创建人。
alex其实是人妖。
谁说alex是sb?
你们真逗,alex再牛逼,也掩饰不住资深屌丝的气质。
----------

将文件中所有的alex都替换成大写的SB。

import os
with open('alex.txt', encoding='utf-8', mode='r') as f1,\
open('SB.txt', encoding='utf-8', mode='w') as f2:
for i in f1:
print(i)
new_i = i.replace('alex', 'SB')
f2.write(new_i)
os.remove('alex.txt')
os.rename('SB.txt', 'alex.txt')

3. 文件a1.txt内容:

文件内容:
name:apple price:10 amount:3 year:2012
name:tesla price:100000 amount:1 year:2013 通过代码,将其构建成这种数据类型:
[{'name':'apple','price':10,'amount':3},
{'name':'tesla','price':1000000,'amount':1}......] # 直接通过a模式创建题目所需要的a1文件
# with open('a1.txt', encoding='utf-8', mode='a') as f1:
# f1.write('name:apple price:10 amount:3 year:2012\n')
# f1.write('name:tesla price:100000 amount:1 year:2013') # 接下来的解题代码如下:
lis = []
dic = {}
with open('a1.txt', encoding='utf-8', mode='r') as f2:
for i in f2:
# 第一次大循环按行转换成列表
li = i.strip().split()
for j in li:
# 小循环里面通过分割':'得到一对键值对
KeyVal = j.split(':')
# 分别赋值给初始的空字典,完成小循环添加完毕
dic.setdefault(KeyVal[0], KeyVal[1])
# 第一行大循环时增添第一行对应的dic字典
lis.append(dic)
# 关键来了,再把字典给清空再进行第二行的大循环,不然小循环里会增添不上。
dic = {}
print(lis)

4,文件a2.txt内容:

文件内容:

序号 部门 人数 平均年龄 备注

1 python 30 26 单身狗

2 Linux 26 30 没对象

3 运营部 20 24 女生多

通过代码,将其构建成这种数据类型:

[{'序号':'1','部门':Python,'人数':30,'平均年龄':26,'备注':'单身狗'},

......]

li = []
with open('a2.txt', encoding='utf-8', mode='r') as f1:
key = f1.readline().strip().split()
# 先读取第一行作为key键的列表元素
# 此时光标己移到第2行开头,再进行后面同样是充当键值的行循环就简单多了
print(key)
for i in f1:
print(i)
val = i.strip().split()
# 以key为基准,循环i次去进行zip函数两个列表合并成字典的操作就简单了
dic = dict(zip(key, val))
li.append(dic)
print(li) 每一步print出来的效果如下,可以更直观看到: ['序号', '部门', '人数', '平均年龄', '备注'] 1 python 30 26 单身狗 2 Linux 26 30 没对象 3 运营部 20 24 女生多 [{'平均年龄': '26', '备注': '单身狗', '部门': 'python', '人数': '30', '序号': '1'},
{'平均年龄': '30', '备注': '没对象', '部门': 'Linux', '人数': '26', '序号': '2'},
{'平均年龄': '24', '备注': '女生多', '部门': '运营部', '人数': '20', '序号': '3'}]

5,明日默写:就是第二题的代码(课上讲过)。

铁乐学Python_day08作业的更多相关文章

  1. 铁乐学Python_day12_作业

    1.写函数,返回一个扑克牌列表,里面有52项,每一项是一个元组 例如:[('红心',2),('草花',2), -('黑桃','A')] def poker(): suit = ['红心', '梅花', ...

  2. 铁乐学python_day10_作业

    1.继续整理函数相关知识点,写博客. 2.写函数,接收n个数字,求这些参数数字的和.(动态传参) def sum_n(*args): sum = 0 for i in args: sum += i r ...

  3. 铁乐学python_day09_作业

    练习题 1.整理函数相关知识点,写博客 2.写函数,检查获取传入列表或元组对象的所有奇数位索引对应的元素, 并将其作为新列表返回给调用者. def odd_index(l): lis = [] for ...

  4. 铁乐学python_Day44_IO多路复用

    目录 IO模型介绍 阻塞IO(blocking IO) 非阻塞IO(non-blocking IO) 多路复用IO(IO multiplexing) 异步IO(Asynchronous I/O) IO ...

  5. 铁乐学python_Day43_协程

    铁乐学python_Day43_协程 引子 之前我们学习了线程.进程的概念,了解了在操作系统中进程是资源分配的最小单位,线程是CPU调度的最小单位. 按道理来说我们已经算是把cpu的利用率提高很多了. ...

  6. 铁乐学python_Day42_线程池

    铁乐学python_Day42_线程池 concurrent.futures 异步调用模块 concurrent.futures模块提供了高度封装的异步调用接口 ThreadPoolExecutor: ...

  7. 铁乐学python_Day42_线程-信号量事件条件

    铁乐学python_Day42_线程-信号量事件条件 线程中的信号量 同进程的一样,Semaphore管理一个内置的计数器, 每当调用acquire()时内置计数器-1:调用release() 时内置 ...

  8. 铁乐学python_Day42_锁和队列

    铁乐学python_Day42_锁和队列 例:多个线程抢占资源的情况 from threading import Thread import time def work(): global n tem ...

  9. 铁乐学python_Day39_多进程和multiprocess模块2

    铁乐学python_Day39_多进程和multiprocess模块2 锁 -- multiprocess.Lock (进程同步) 之前我们千方百计实现了程序的异步,让多个任务可以同时在几个进程中并发 ...

随机推荐

  1. 剑指offer63:数据流中的中位数

    题目描述: 如何得到一个数据流中的中位数?如果从数据流中读出奇数个数值,那么中位数就是所有数值排序之后位于中间的数值.如果从数据流中读出偶数个数值,那么中位数就是所有数值排序之后中间两个数的平均值. ...

  2. SpringBoot入门 (六) 数据库访问之Mybatis

    本文记录学习在SpringBoot中使用Mybatis. 一 什么是Mybatis MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 ...

  3. nodejs zip压缩版安装与配置

    Node.js 1.下载 下载地址:https://nodejs.org/zh-cn/download/ 选择相应的版本下载 2.解压缩 将文件解压到要安装的位置,并新建两个目录 node-globa ...

  4. 不会几个框架,都不好意思说搞过前端: React 入门实例教程

    现在最热门的前端框架,毫无疑问是 React . 上周,基于 React 的 React Native 发布,结果一天之内,就获得了 5000 颗星,受瞩目程度可见一斑. React 起源于 Face ...

  5. 通过spark-sql快速读取hive中的数据

    1 配置并启动 1.1 创建并配置hive-site.xml 在运行Spark SQL CLI中需要使用到Hive Metastore,故需要在Spark中添加其uris.具体方法是将HIVE_CON ...

  6. 【转】外国朋友出的js题目,你能对几道

    原文地址 http://perfectionkills.com/javascript-quiz/ 中文地址加解释:by Aaron:http://www.cnblogs.com/aaronjs/p/3 ...

  7. (二)this、call和apply

    在javascript中,this关键字总让一些初学者迷惑,Function.prototype.call, Function.prototype.apply这两个方法广泛的运用.我们有必要理解这几个 ...

  8. Resharper 使用帮助-自动生成文件头

    VS2012 安装完resharper 后,在resharper选项中选择 Code Editing – File Header Text . 输入自定义的文件头格式.如果需要在文件头外层添加regi ...

  9. ASP.NET Core 2 学习笔记(十四)Filters

    Filter是延续ASP.NET MVC的产物,同样保留了五种的Filter,分别是Authorization Filter.Resource Filter.Action Filter.Excepti ...

  10. ACK-Ackermann, 阿克曼函数

    以前好几次在学语言的使用都有实现这个ack函数的经历,今天读本算法书,偶尔又提到了这个,查了下wiki来头好大 Values of A(m, n) m\n 0 1 2 3 4 n 0 1 2 3 4 ...