python之道08

Posted zanao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python之道08相关的知识,希望对你有一定的参考价值。

1.有如下文件,a1.txt,里面的内容为:


某某是最好的学校,

全心全意为学生服务,

只为学生未来,不为牟利。

我说的都是真的。哈哈


分别完成以下的功能:

a,将原文件全部读出来并打印。

答案

f = open('a1.txt',mode='r')
print(f.read())
f.close()
'''
输出结果
老男孩是最好的学校,
全心全意为学生服务,
只为学生未来,不为牟利。
我说的都是真的。哈哈

'''

b,在原文件后面追加一行内容:信不信由你,反正我信了。

答案

f = open('a1.txt',mode='a')
f.write('信不信由你,反正我信了')
f.close()
'''
老男孩是最好的学校,
全心全意为学生服务,
只为学生未来,不为牟利。
我说的都是真的。哈哈信不信由你,反正我信了
'''

c,将原文件全部读出来,并在后面添加一行内容:信不信由你,反正我信了。

答案

f = open('a1.txt',mode='r+')
f.read()
f.write('信不信由你,反正我信了')
f.close()
'''
老男孩是最好的学校,
全心全意为学生服务,
只为学生未来,不为牟利。
我说的都是真的。哈哈信不信由你,反正我信了
'''

d,将原文件全部清空,换成下面的内容:


每天坚持一点,

每天努力一点,

每天多思考一点,

慢慢你会发现,

你的进步越来越大。

答案

f = open('a1.txt',mode='w')
f.write('''
每天坚持一点,

每天努力一点,

每天多思考一点,

慢慢你会发现,

你的进步越来越大。
''')
f.close()

2.有如下文件,t1.txt,里面的内容为:


葫芦娃,葫芦娃,

一根藤上七个瓜

风吹雨打,都不怕,

啦啦啦啦。

我可以算命,而且算的特别准:

上面的内容你肯定是心里默唱出来的,对不对?哈哈


分别完成下面的功能:

a,以r的模式打开原文件,利用for循环遍历文件句柄。

答案

f = open('t1.txt',mode='r')
for i in f:
    print(i)
f.close()

b,以r的模式打开原文件,以readlines()方法读取出来,并循环遍历 readlines(),并分析b,与c 有什么区别?深入理解文件句柄与 readlines()结果的区别。

c,以r模式读取‘葫芦娃,’前四个字符。

答案

b.
f = open('t1.txt',mode='r')
print(f.readlines())
f.close()
'''
['葫芦娃,葫芦娃,\n', '\n', '一根藤上七个瓜\n', '\n', '风吹雨打,都不怕,\n', '\n', '啦啦啦啦。\n', '\n', '我可以算命,而且算的特别准:\n', '\n', '上面的内容你肯定是心里默唱出来的,对不对?哈哈']
'''
c. 
f = open('t1.txt',mode='r')
print(f.read(4))
f.close()
'''
葫芦娃,
'''
b,与c 有什么区别:
1. readlines()一行一行读取全部文件,且结尾会有换行符\n
2. read()是一口气读取全部内容,如果文件文很大容易内存溢出

d,以r模式读取第一行内容,并去除此行前后的空格,制表符,换行符。

答案

f = open('t1.txt',mode='r')
f1 = f.readline().strip().split('\n')
print(f1)
f.close()
'''
['葫芦娃,葫芦娃,']
'''

e,以a+模式打开文件,先追加一行:‘老男孩教育’然后在从最开始将 原内容全部读取出来。

答案

f = open('t1.txt',mode='a+')
f.write('\n'+'老男孩教育')
f.seek(0)
print(f.read())
f.close
'''
葫芦娃,葫芦娃,

一根藤上七个瓜

风吹雨打,都不怕,

啦啦啦啦。

我可以算命,而且算的特别准:

上面的内容你肯定是心里默唱出来的,对不对?哈哈

老男孩教育
'''

3.文件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......] 并计算出总价钱。

答案

lis = []
key_list = ['name','price','amount']
num = 0
with open('a.txt',mode='r') as f:
    for l in f:
        l_list = l.strip().split()
        dic = key_list[0]:l_list[0],key_list[1]:l_list[1],key_list[2]:l_list[2]
        lis.append(dic)
        num = num + int(l_list[1]) * int(l_list[2])
print(lis)
print('总价格为:',num)

'''
['name': 'apple', 'price': '10', 'amount': '3', 'name': 'tesla', 'price': '100000', 'amount': '1', 'name': 'mac', 'price': '3000', 'amount': '2', 'name': 'lenovo', 'price': '30000', 'amount': '3', 'name': 'chicken', 'price': '10', 'amount': '3']
总价格为: 196060
'''

4.有如下文件:


alex是老男孩python发起人,创建人。

alex其实是人妖。

谁说alex是sb?

你们真逗,alex再牛逼,也掩饰不住资深屌丝的气质。


将文件中所有的alex都替换成大写的SB(文件的改的操作)。

答案

with open('a.txt',mode='r') as f,    open('a.txt_bak',mode='w+') as f2,    open('new_a.txt',mode='a') as f1:

    for i in f:
        content = i.replace('alex','SB')
        f1.write(content)
import os
os.rename('./a.txt_bak','a.txt')
os.rename('new_a.txt','a.txt')

5.文件a1.txt内容(升级题)


name:apple price:10 amount:3 year:2012

name:tesla price:100000 amount:1 year:2013



.......


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

[‘name‘:‘apple‘,‘price‘:10,‘amount‘:3,year:2012,

‘name‘:‘tesla‘,‘price‘:1000000,‘amount‘:1......]

并计算出总价钱。

答案

# 方法一:

lis = []
my_sum = 0
with open('a1.txt',mode='r') as f:
    for i in f:
        x = i.split()
        dic1 = 
        for i1 in x:
            k = i1.split(':')[0]
            v = i1.split(':')[1]
            dic1[k]=v
        lis.append(dic1)
print(lis)
for em in lis:
    sum = int(em['price'])* int(em['amount'])
    my_sum += sum
print(my_sum)

'''
输出结果
['name': 'apple', 'price': '10', 'amount': '3', 'year': '2012', 'name': 'tesla', 'price': '100000', 'amount': '1', 'year': '2013']
100030
'''

# 方法二:
result_list=[]
sum=0
with open('a1.txt',encoding='gbk') as f:
    for line in f:
        line_list=line.strip().split()
        d=
        for i in line_list:
            key, value=i.split(':')
            if value.isdecimal():
                value=int(value)
            d.setdefault(key,value)
        sum+=d['price']*d['amount']
        result_list.append(d)
print(result_list)
print(sum)
'''
输出结果
['name': 'apple', 'price': 10, 'amount': 3, 'year': 2012, 'name': 'tesla', 'price': 100000, 'amount': 1, 'year': 2013]
100030
'''

6.文件a1.txt内容(升级题)


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

1 python 30 26 单身狗

2 Linux 26 30 没对象

3 运营部 20 24 女生多


.......


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

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

......]

答案

# 方法一
l1 = []
dic = 
with open('a1.txt',mode='r') as f:
    f1 = f.readline()
    for i in f:
        a= i.split()
        # print(a)
        dic='序号':a[0],'部门':a[1],'人数':a[2],'平均年龄':a[3],'备注':a[4]
        l1.append(dic)
print(l1)
'''
输出结果
['序号': '1', '部门': 'python', '人数': '30', '平均年龄': '26', '备注': '单身狗', '序号': '2', '部门': 'Linux', '人数': '26', '平均年龄': '30', '备注': '没对象', '序号': '3', '部门': '运营部', '人数': '20', '平均年龄': '24', '备注': '女生多']
'''
# 方法二
count=0
keys_list=[]
class_list=[]
result_list=[]
with open('a1.txt',encoding='gbk') as f:
    for line in f:
        count += 1
        if count==1:
            keys_list=line.strip().split()
            continue
        else:
            class_list=line.strip().split()
        d = 
        for j in range(len(keys_list)):
            if class_list[j].isdecimal():
                d.setdefault(keys_list[j],int(class_list[j]))
            else:
                d.setdefault(keys_list[j], class_list[j])
        result_list.append(d)
    print(result_list)

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

以上是关于python之道08的主要内容,如果未能解决你的问题,请参考以下文章

《Python黑帽子:黑客与渗透测试编程之道》读书笔记:网络基础

代码简洁之道:一行Python代码解决问题是时尚还是玄学

python之道13

python之道09

python之道04

我在哪里更改此 Python 代码片段以将临时文件保存在 tmp 文件夹中?