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. [Codeforces 925C]Big Secret

    Description 题库链接 给出 \(n\) 个数,让你生成这 \(n\) 个数的一个排列 \(A\) .定义 \(B_i = \bigoplus\limits_{j=1}^i A_j\) , ...

  2. Cache写机制:Write-through与Write-back

    cache through https://www.cnblogs.com/gordonkong/p/7161809.html 原文地址:https://blog.csdn.net/wyzxg/art ...

  3. .NET环境下使用水晶报表

    .NET环境下使用水晶报表 听语音 | 浏览:3280 | 更新:2013-12-20 13:36 1 2 3 4 5 6 7 分步阅读 水晶报表(Crystal Reports)-商务智能软件,通常 ...

  4. bootstrap、qjuery、插件 、字体网页

    http://www.bootcss.com/ 前端框架bootstrap http://www.fontawesome.com.cn/faicons/ 字体图标库 https://daneden.g ...

  5. 如何在PIXI.js里面使用json文件来管理瓦片集(tileset)?

    如何在PIXI.js里面使用json文件来管理瓦片集(tileset)? PIXI建议我们将素材图片汇总成一个瓦片集(tileset),然后用纹理地图集(texture atlas,通常是一个json ...

  6. MQ与Webservice的区别

    Webservice 和MQ(MessageQueue)都是解决跨平台通信的常用手段,两者有哪些区别呢? 个人认为最本质的区别在于 Webservice近乎实时通信,而MQ却通常是延时通信. 什么意思 ...

  7. [js常用]连续播放音频

    许多音频连续播放.有的时候音频过大会分成多个音频.播放的时候需要连续播放 <!DOCTYPE HTML> <html> <head> <meta charse ...

  8. 一文理解JS的节流、防抖及使用场景

    函数防抖(debounce):在事件被触发n秒后再执行回调,如果在这n秒内又被触发,则重新计时. 看一个

  9. 第二十二天- 序列化 pickle json shelve

    # 序列化:存储或传输数据时,把对象处理成方便存储和传输的数据格式,这个过程即为序列化# Python中序列化的三种方案:# 1.pickle python任意数据——>bytes写入⽂件:写好 ...

  10. 12:计算2的N次方

    12:计算2的N次方 查看 提交 统计 提问 总时间限制:  1000ms 内存限制:  65536kB 描述 任意给定一个正整数N(N<=100),计算2的n次方的值. 输入 输入一个正整数N ...