自己敲一遍这个代码,注释我写的超级详细,一定可以明白!
知识点学习参考:
1.基本读写常用指令:
一文搞懂Python文件读写 - 知乎 (zhihu.com)
2.文件遍历知识总结:
(205条消息) python遍历文件夹下的所有文件_python遍历d盘下面所有文件(排除掉文件夹)_热巴的小哥哥的博客-CSDN博客
3. isdir函数详解: Python判断路径是否是目录-Python isdir函数-嗨客网 (haicoder.net)
目录
第1关:读取文件内容
第2关:素数写入文件
第3关:输出文件目录
第4关:读写json文件
第1关:读取文件内容
def file(name,encoding = 'utf-8'):'''读取文件内容,如文件存在,则输出文件信息,若文件不存在,则输出`无法打开指定的文件!`,若文件编码方案和打开指定编码方案不同,则输出`指定了未知的编码!`,若读取文件时解码错误,则输出`读取文件时解码错误!`:params name:文件名:params encoding:编码方案。默认为'utf-8':return :无返回值,直接输出'''# 请在此处添加代码 ## *************begin************##我的代码逻辑:if(文件存在与否) else#情况1:编码方案相同if encoding == 'utf-8': #编码方案默认为utf-8# ① 文件存在try:f = open(name) #第一步:用open()来打开文件后,可以用open各种方法print(f.read()) #read:读取一些数据,作为字符串(文本模式下)或 字节对象(二进制模式下)返回。默认读取文件全部# ② 文件不存在except FileNotFoundError:print('无法打开指定的文件!')#情况2:编码方案不同else: print('指定了未知的编码!')# **************end*************#
if __name__ == '__main__':name,encoding = input().split(',')file(name=name,encoding=encoding)
第2关:素数写入文件
from math import sqrt
def is_prime(n):"""判断素数的函数"""assert n > 0for factor in range(2, int(sqrt(n)) + 1):if n % factor == 0:return Falsereturn True if n != 1 else Falsedef store():# 请在此处添加代码 ## *************begin************##文件1:1-99素数with open("a.txt",'w') as f: # with:最好写上,当子句体结束后,文件会正确关闭,即使异常无碍for i in range(2,100):if is_prime(i):f.write(str(i) + "\n")#文件2:100-999素数with open("b.txt",'w') as f:for i in range(100,1000):if is_prime(i):f.write(str(i) + "\n")#文件3:1000-9999素数with open("c.txt",'w') as f:for i in range(1000,10000):if is_prime(i):f.write(str(i) + "\n")# **************end*************#
第3关:输出文件目录
from os import listdir #os模块的listdir方法;返回目标路径下文件和文件夹的名字列表,参数=目标路径
from os.path import join,isfile,isdir # os.listdir(r'E:\test')
def listDir(director): """ os模块中相关文件目录操作遍历文件夹,如果是文件就直接输出当前文件绝对路径,如果是文件夹,就输出当前文件夹路径,然后接着遍历该子文件夹,直到指定文件夹被全部遍历完。:param director: 需遍历的路径:return:无返回值,直接输出"""# 请在此处添加代码 ## *************begin************## 1.不是目录if not isdir(director): #isdir:判断是否是目录printf("no")return# 2.是目录for x in listdir(director): #遍历temp = join(director,x) #join:连接字符串,数组,元素序列,字典,元组#文件if isfile(temp):print(temp)elif isdir(temp):print(temp)listDir(temp)# **************end*************#
第4关:读写json文件
import json
def main(name):# 请在此处添加代码 ## *************begin************#attribute = [] # attribute:存储对象属性+特征(eg: 年龄,性别,身高)ans = [] #ans: anser存储某个结果或答案的属性(eg: 数学结果)try: #try except:捕获可能出现的异常,防止程序中断with open(name,'r') as f:#打开一个名为name的文本文件(只读模式打开)title = f.readline() #读取文件的第一行(标题行)title = title.replace("\n","").split(" ") #去掉标题行中换行符,使用空格将字符串分割成一个列表while True: #无限循环,直到breakcontent = f.readline() #读取下一行if content == "":break #内容=空,结束循环content = content.replace("\n","").split(" ") #去换行符,分割列表temp = dict(zip(title,content)) #zip 一一对应,换成字典ans.append(temp) #加入列表ans中 append:末尾添加一个元素print(ans)except Exception as e:print(e) #文本文件以字典列出,方便后续处理# **************end*************#if __name__ == '__main__':name = input()main(name)