FIsh论坛《零基础入门学习Python》| 第029讲 课后测试题及答案

2024-03-29 16:08

本文主要是介绍FIsh论坛《零基础入门学习Python》| 第029讲 课后测试题及答案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

FIsh论坛《零基础入门学习Python》| 第029讲文件:一个任务 | 课后测试题及答案

动动手:

0.编写一个程序,接受用户的输入并保存为新的文件,程序实现如图:
在这里插入图片描述

def new_file(file_name):f = open (file_name , "w")print("请输入内容[单独输入':w'保存退出]:")while True:write_some = input()if write_some != ':w':f.write("%s\n" % write_some)else:breakf.close()
file_name = input("请输入文件名:")
new_file(file_name)输出结果:请输入文件名:55
请输入内容[单独输入':w'保存退出]:
从明天起,做一个幸福的人
喂马、劈柴,周游世界
从明天起,关心粮食和蔬菜
我有一所房子,面朝大海,春暖花开
书法作品
书法作品
从明天起,和每一个亲人通信
告诉他们我的幸福
那幸福的闪电告诉我的
我将告诉每一个人
给每一条河每一座山取一个温暖的名字
陌生人,我也为你祝福
愿你有一个灿烂的前程
愿你有情人终成眷属
愿你在尘世获得幸福
我只愿面朝大海,春暖花开
:w

1.编写一个程序,比较用户输入的两个文件,如果不同,显示出所有不同处的行号与第一个不同字符的位置,程序实现如图:
在这里插入图片描述

# 同一文件夹内比较
def file_compare(file1,file2):f1 = open(file1,"r")f2 = open(file2,"r")count = 0differ = []for each_line1 in f1:each_line2 = f2.readline()count += 1if each_line1 != each_line2:differ.append(count)f1.close()f2.close()return differfile1 = input("请输入需要比较的头一个文件名:")
file2 = input("请输入需要比较的后一个文件名:")differ = file_compare(file1,file2)
if len(differ) == 0:print("两个文件完全一样。")
else:print("两个文件有%d处不同" % len(differ) )for each in differ:print("第%d行不一样" % each)
输出结果:
请输入需要比较的头一个文件名:001.txt
请输入需要比较的后一个文件名:test1.txt
Traceback (most recent call last):File "D:/PycharmProjects/pythonProject/venv/001.py", line 28, in <module>differ = file_compare(file1,file2)File "D:/PycharmProjects/pythonProject/venv/001.py", line 10, in file_comparef1 = open(file1,"r")
FileNotFoundError: [Errno 2] No such file or directory: '001.txt'

2.编写一个程序,当用户输入文件名和行数(N)后,将该文件的前N行内容打印在屏幕上,程序实现如图:
在这里插入图片描述
参考代码:
大致思路,print(i),i为input的行数

def read_file(file,num):f = open(file)each_line_length = len(file)if num == 0:print(" ")if each_line_length <= num:print("文件行数只有%d行,已全部读取"% each_line_length)for each_line in f :print(each_line)else:# 读取前多少行for i in range(num):print(f.readline(),end = "")f.close()file = input("请输入要打开的文件名(带路径):")
num = int (input("请输入需要显示改文件前几行:"))
read_file(file,num)
def file_view(file_name,file_num):print("\n文件%s的前%s的内容如下:\n" % (file_name,file_num))f = open(file_name)for i in range(int(file_num)):print(f.readline(),end = " ")f.close()
file_name = input("请输入要打开的文件名(带路径):")
file_num = (input("请输入需要显示改文件前几行:"))
file_view(file_name,file_num)

3.在上一题的基础上进行扩展,用户可以随意输入需要显示的行数(如果输入13:21打印第13行到21行,输入为:21打印前21行,输入21:则打印从第21行开始到文件结尾所有内容)
在这里插入图片描述
大致思路:只需要修改输出的判断条件即可

def read_file(file,num1):f = open(file)list1 = list(num1.split(":")) #这里为啥要分割# print(list1)begin = list1[0]end = list1[1]if begin == "":begin = 1if end =="":end = -1if begin ==1 and end == -1:temp = "全文"# 显示全文# print(f.readline())elif begin ==1:temp = "从开始到%d行" % endelif end == -1:temp = "从%d行到最后" % beginelse:temp = "从%s到%s行" % (begin,end)print("文件%s" % file +temp+"的内容如下:" )begin = int(begin)-1end = int (end )lines = end-begineach_line_length = len(file)# 消耗掉。不显示内容for i in range(begin):f.readline()if lines <0:print(f.read())else:for j in range(lines):print(f.readline(),end= "")f.close()file = input("请输入要打开的文件名(带路径):")
num1 = input("请输入需要显示该文件行数【格式如13:21或:21或13:或:】:")
read_file(file,num1)

4.编写一个程序,实现“全部替换”功能,程序实现如图:
在这里插入图片描述
大致思路:
count进行计数
找出所有需要替换的字符,替换用什么内置函数呢?

def file_replace(file_name,old_word,new_word):f = open(file_name)count= 0content = []num =0for eachline in f :num  += 1if old_word in eachline:count += eachline.count(old_word)eachline = eachline.replace(old_word, new_word)content.append(eachline)else:content.append(eachline)print("文件中共有"+str(count)+"个"+old_word)prompt = input("您确定要把所有的"+old_word+"替换成"+new_word+"吗?【YES/NO】")if prompt  in ['YES','yes','Yes']:f_write = open(file_name,"w")for i in range(len(content)):temp = str(content[i])f_write.writelines(temp)f_write.close()f.close()file_name = input("请输入文件名:")
old_word = input("请输入需要替换的单词和字符:")
new_word = input("请输入新的单词或者字符:")
file_replace(file_name,old_word,new_word)
输出结果:
请输入文件名:E:/test.txt
请输入需要替换的单词和字符:1
请输入新的单词或者字符:2
文件中共有9个1
您确定要把所有的1替换成2吗?【YES/NO】yesProcess finished with exit code 0

这篇关于FIsh论坛《零基础入门学习Python》| 第029讲 课后测试题及答案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/859036

相关文章

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

Python Web框架Flask、Streamlit、FastAPI示例详解

《PythonWeb框架Flask、Streamlit、FastAPI示例详解》本文对比分析了Flask、Streamlit和FastAPI三大PythonWeb框架:Flask轻量灵活适合传统应用... 目录概述Flask详解Flask简介安装和基础配置核心概念路由和视图模板系统数据库集成实际示例Stre

Python实现PDF按页分割的技术指南

《Python实现PDF按页分割的技术指南》PDF文件处理是日常工作中的常见需求,特别是当我们需要将大型PDF文档拆分为多个部分时,下面我们就来看看如何使用Python创建一个灵活的PDF分割工具吧... 目录需求分析技术方案工具选择安装依赖完整代码实现使用说明基本用法示例命令输出示例技术亮点实际应用场景扩

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo

基于Python实现简易视频剪辑工具

《基于Python实现简易视频剪辑工具》这篇文章主要为大家详细介绍了如何用Python打造一个功能完备的简易视频剪辑工具,包括视频文件导入与格式转换,基础剪辑操作,音频处理等功能,感兴趣的小伙伴可以了... 目录一、技术选型与环境搭建二、核心功能模块实现1. 视频基础操作2. 音频处理3. 特效与转场三、高

Python实现中文文本处理与分析程序的示例详解

《Python实现中文文本处理与分析程序的示例详解》在当今信息爆炸的时代,文本数据的处理与分析成为了数据科学领域的重要课题,本文将使用Python开发一款基于Python的中文文本处理与分析程序,希望... 目录一、程序概述二、主要功能解析2.1 文件操作2.2 基础分析2.3 高级分析2.4 可视化2.5

一文解密Python进行监控进程的黑科技

《一文解密Python进行监控进程的黑科技》在计算机系统管理和应用性能优化中,监控进程的CPU、内存和IO使用率是非常重要的任务,下面我们就来讲讲如何Python写一个简单使用的监控进程的工具吧... 目录准备工作监控CPU使用率监控内存使用率监控IO使用率小工具代码整合在计算机系统管理和应用性能优化中,监