【python基础知识】16.“古诗默写题”的python实现(文件读写和编码-实操篇)

简介: 【python基础知识】16.“古诗默写题”的python实现(文件读写和编码-实操篇)

前言


回顾一下之前学到的编码和文件读写。


不同的编码方式:

1.png

编码和解码:2.png

读文件的三步骤:3.png

写文件的三步骤:4.png不同的读写方式:5.png

好了,复习到此结束,接下来一起来做项目吧!


练习介绍


练习目标


这个练习,会让你学会一种方法,可以直接修改原文件中的数据。


练习要求


语文老师将一些古诗存在txt文档里,一句一行。


最近,他计划抽一些古诗,自己设置一些空来让学生默写。


请你用代码帮老师完成这项工作(只要处理了一个文档,加上循环就能处理无数个文档了)。


项目实操


明确目标


我们以李商隐的《锦瑟》为例,这是原文档里的内容:

锦瑟
[唐] 李商隐
锦瑟无端五十弦,
一弦一柱思华年。
庄生晓梦迷蝴蝶,
望帝春心托杜鹃。
沧海月明珠有泪,
蓝田日暖玉生烟。
此情可待成追忆,
只是当时已惘然。

老师在这首诗想考学生“一弦一柱思华年。”和“只是当时已惘然。”,即他想得到的是:

锦瑟
[唐] 李商隐
锦瑟无端五十弦,
__。
庄生晓梦迷蝴蝶,
望帝春心托杜鹃。
沧海月明珠有泪,
蓝田日暖玉生烟。
此情可待成追忆,
__。

分析过程,拆解项目


准备工作


先新建一个poem1.txt,然后将以下古诗内容复制到里面,并且保存,放到与.py文件同目录下。

锦瑟
[唐] 李商隐
锦瑟无端五十弦,
一弦一柱思华年。
庄生晓梦迷蝴蝶,
望帝春心托杜鹃。
沧海月明珠有泪,
蓝田日暖玉生烟。
此情可待成追忆,
只是当时已惘然。

梳理思路


最终结果是要将“一弦一柱思华年。”和“只是当时已惘然。”这两句古诗用“__”来代替。


那首先我们就要能找到这两句古诗,所以思路如下:


1.找到poem1.txt文件


2.逐行读取该文件中的内容


3.逐行判断该行的内容是否是要找的两句古诗:“一弦一柱思华年。”和“只是当时已惘然。”如果是,就替换为“——”并写入poem2.txt文件,如果不是就原样写入test.txt文件.


代码实现,逐步执行


【第1步-开】


使用open()函数打开文件。

with open('poem1.txt', 'r', encoding='utf-8') as f:

open('poem1.txt', 'r', encoding='utf-8'):使用 open() 函数打开名为 poem1.txt 的文本文件。第一个参数是文件路径,第二个参数 'r' 表示以只读模式打开文件,第三个参数 'utf-8' 指定文件编码为 UTF-8。


with 语句:使用 with 打开文件,可以确保在操作完成后自动关闭文件,同时能够处理异常情况。

第2步-读】

lines = f.readlines()
print(lines)

f.readlines()使用文件对象 freadlines() 方法,读取所有行,并将它们存▪▪储在一个列表 lines中。


print(lines):打印读取到的内容,这里是文件的所有行。注意,输出的每一行都会带有换行符 \n


【第3步-文件写入&逻辑判断】

with open('test.txt', 'w', encoding='utf-8') as new:
    for line in lines:
        if line not in ['一弦一柱思华年。\n', '只是当时已惘然。\n']:
            new.write(line)
        else:
            new.write('____________\n')

open('test.txt', 'w', encoding='utf-8'):使用 open() 函数以写入模式打开名为 test.txt 的文件。第一个参数是文件路径,第二个参数 'w' 表示以写入模式打开文件(会覆盖原有内容),第三个参数 'utf-8' 指定文件编码为 UTF-8。


with 语句:使用 with 打开文件,确保在操作完成后自动关闭文件。


for line in lines::遍历 lines 列表中的每一行。


if line not in ['一弦一柱思华年。\n', '只是当时已惘然。\n']::检查当前行是否不等于给定的两行文本。


new.write(line):如果当前行不满足条件,则将其写入名为 new 的文件中。


else::如果当前行满足条件,则将 '____________\n' 写入文件中。


【第4步-关】


由于使用 with 打开文件,在操作完成后会自动关闭文件。无需再专门写关闭的代码。


完整代码:

with open ('poem1.txt','r',encoding='utf-8') as f:
    lines = f.readlines()  # 这时,lines 的数据存放在内存里。
print(lines)  # 将读取到的内容打印出来,发现实际上读到的是带换行符的字符串。
with open('test.txt','w',encoding='utf-8') as new:
    for line in lines:  # 在内存中,对数据进行处理,然后再写到文档里,覆盖之前的内容。
        if line not in ['一弦一柱思华年。\n','只是当时已惘然。\n']:  # 注意:这里的条件要根据上面打印出的数据写。
            new.write(line)
        else:
            new.write('____________\n')

这段代码的功能是将 poem1.txt 中的内容读取到内存中,进行处理后,再覆盖写入到 test.txt 文件中。具体处理方式是,如果某一行与给定的两行文本相等,则在 test.txt 中写入 '____________\n',否则直接将原始行写入 test.txt


另一种写法:


也可以将目标语句放到一个list中,在判断的时候,如果属于这个list,就替换为“____________”


代码如下:

list_test = ['一弦一柱思华年。\n','只是当时已惘然。\n']  # 将要默写的诗句放在列表里。
with open ('poem1.txt','r') as f:
    lines = f.readlines()
print(lines)
with open('test.txt','w') as new:
    for line in lines:
        if line in list_test:  # 属于默写列表中的句子,将其替换成横线。
            new.write('____________。\n')
        else:
            new.write(line)

总结


通过这个项目的实操,我们掌握并巩固了以下几个知识点:


1.文件操作:学习如何使用 Python 进行文件的读写操作。通过 open() 函数打开文件,使用 'r' 模式进行读取,使用 'w' 模式进行写入。


2.上下文管理器:学习如何使用 with 语句来打开文件。with 语句可以确保在操作完成后自动关闭文件,同时能够处理异常情况,提高代码的健壮性。


3.读取文件内容:学习使用 readlines() 方法从文件对象中读取所有行,并将其存储在一个列表中。这样可以方便地对文件内容进行处理和操作。


4.字符串比较和处理:学习如何对读取到的文本字符串进行条件判断和处理。在示例代码中,通过判断是否与给定两行文本相等,来决定是否写入 '____________\n' 或原始行到目标文件。


5.文件编码设置:学习如何设置文件的编码。示例中使用了 'utf-8' 编码,确保正确读取和写入包含非英文字符的文本。


通过理解和应用这些知识点,可以更好地处理和操作文本文件,扩展其对文件操作的基础能力。


总结为表格:


下面是使用 Markdown 格式总结这段代码可以学到的知识的表格:

知识点

描述

文件操作

学习如何使用 Python 进行文件的读写操作

上下文管理器

学习如何使用 with 语句来打开文件,自动关闭文件,并处理异常情况

读取文件内容

学习使用 readlines() 方法从文件对象中读取所有行,并存储在列表中
字符串比较处理 学习如何对读取到的文本字符串进行条件判断和处理
文件编码设置 学习如何设置文件的编码,以确保正确读取和写入包含非英文字符的文本

本节完美结束,撒花~希望大家多多练习,早日成为大神!

相关文章
|
1月前
|
自然语言处理 数据处理 Python
python操作和解析ppt文件 | python小知识
本文将带你从零开始,了解PPT解析的工具、工作原理以及常用的基本操作,并提供具体的代码示例和必要的说明【10月更文挑战第4天】
305 60
|
29天前
|
安全 Linux 数据安全/隐私保护
python知识点100篇系列(15)-加密python源代码为pyd文件
【10月更文挑战第5天】为了保护Python源码不被查看,可将其编译成二进制文件(Windows下为.pyd,Linux下为.so)。以Python3.8为例,通过Cython工具,先写好Python代码并加入`# cython: language_level=3`指令,安装easycython库后,使用`easycython *.py`命令编译源文件,最终生成.pyd文件供直接导入使用。
python知识点100篇系列(15)-加密python源代码为pyd文件
|
11天前
|
开发者 Python
Python中__init__.py文件的作用
`__init__.py`文件在Python包管理中扮演着重要角色,通过标识目录为包、初始化包、控制导入行为、支持递归包结构以及定义包的命名空间,`__init__.py`文件为组织和管理Python代码提供了强大支持。理解并正确使用 `__init__.py`文件,可以帮助开发者更好地组织代码,提高代码的可维护性和可读性。
15 2
|
1月前
|
Linux 区块链 Python
Python实用记录(十三):python脚本打包exe文件并运行
这篇文章介绍了如何使用PyInstaller将Python脚本打包成可执行文件(exe),并提供了详细的步骤和注意事项。
51 1
Python实用记录(十三):python脚本打包exe文件并运行
|
24天前
|
Python
python读写操作excel日志
主要是读写操作,创建表格
50 2
|
27天前
|
Java Python
> python知识点100篇系列(19)-使用python下载文件的几种方式
【10月更文挑战第7天】本文介绍了使用Python下载文件的五种方法,包括使用requests、wget、线程池、urllib3和asyncio模块。每种方法适用于不同的场景,如单文件下载、多文件并发下载等,提供了丰富的选择。
|
28天前
|
数据安全/隐私保护 流计算 开发者
python知识点100篇系列(18)-解析m3u8文件的下载视频
【10月更文挑战第6天】m3u8是苹果公司推出的一种视频播放标准,采用UTF-8编码,主要用于记录视频的网络地址。HLS(Http Live Streaming)是苹果公司提出的一种基于HTTP的流媒体传输协议,通过m3u8索引文件按序访问ts文件,实现音视频播放。本文介绍了如何通过浏览器找到m3u8文件,解析m3u8文件获取ts文件地址,下载ts文件并解密(如有必要),最后使用ffmpeg合并ts文件为mp4文件。
|
1月前
|
JSON 数据格式 Python
Python实用记录(十四):python统计某个单词在TXT/JSON文件中出现的次数
这篇文章介绍了一个Python脚本,用于统计TXT或JSON文件中特定单词的出现次数。它包含两个函数,分别处理文本和JSON文件,并通过命令行参数接收文件路径、目标单词和文件格式。文章还提供了代码逻辑的解释和示例用法。
41 0
Python实用记录(十四):python统计某个单词在TXT/JSON文件中出现的次数
|
1月前
|
Python
Python实用记录(十二):文件夹下所有文件重命名以及根据图片路径保存到新路径下保存
这篇文章介绍了如何使用Python脚本对TTK100_VOC数据集中的JPEGImages文件夹下的图片文件进行批量重命名,并将它们保存到指定的新路径。
32 0
|
1月前
|
Python
如何利用Python快捷地操作文件和文件夹
关注B站用户“肆十二-”,观看更多实战教学视频。本文介绍Python的shutil库,涵盖文件和文件夹的复制、移动、删除及归档等高级操作,提供实用代码示例。
24 0