美文网首页大数据 爬虫Python AI Sql扣丁学堂Python培训
扣丁学堂Python培训之文件读写保存操作示例代码详解

扣丁学堂Python培训之文件读写保存操作示例代码详解

作者: 994d14631d16 | 来源:发表于2018-09-17 11:40 被阅读0次

  今天扣丁学堂Python培训老师给大家介绍一下关于Python开发文件读写保存操作的示例代码,并实现了单个文件和多文件的读写保存操作记录,下面我们一起来看一下吧。

  单个文件的读操作:

  我们先假设一个需求如下:

  读取一个test.txt文件

  删除指定字符之前的文本

  需求明白之后,下面开始动手写代码,代码很简单。就直接上全部的,细节看注释:

  importsys

  filePath="/Users/xxxxxx/Desktop/test.txt"

  #打开文件

  files=open(filePath,'r')

  #转成list

  f_list=files.readlines()

  tempIndex=0

  #对f_list循环每个index对应一行数据

  forindexinrange(len(f_list)):

  #temp是获取一行的数据

  temp=f_list[index]

  #判断"test"是不是temp这行数据的首位如果是首位result为true

  result=temp.find("test")==0

  ifresult:

  #如果是首位这就是我们要删除的位置获取他的index

  tempIndex=index

  break

  #存放新数据

  tempContainer=[]

  forindexinrange(len(f_list)):

  ifindex>tempIndex:

  #tempIndex之前的数据我们不处理,把tempindex之后的数据存到新的list里面

  tempContainer.append(f_list[index])

  #这就获得了我们需要的新数据

  print(tempContainer)

  以上代码就完成了需求,非常简单。有几个注意点:

  直接用open获取的数据无法进行处理,所以先转成可以处理的数据,比如list或者字典等。

  python的open和C的类似,有r,r+,w,w+等各种状态,见具体介绍

  open函数的常见操作方式

  1、r打开只读文件,该文件必须存在。

  2、r+打开可读写的文件,该文件必须存在。

  3、w打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。

  4、w+打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。

  多文件读写保存

  假设一个需求如下:

  多个文件都要处理

  和上面的test.txt处理方式类似

  处理完之后保存到一个新文件夹内

  其实这个需求实质上只是比单文件读操作只多了一个写操作。其他的就是逻辑稍微绕一下

  怎么同时操作多个文件

  然后怎么保存成多个文件

  肯定是不能一个文件一个文件的去操作,太麻烦了。说下我的实现思路:

  把文件放在一个文件夹内

  获取这个文件夹内所有的文件名,拼接成文件路径

  然后创建一个空的新文件夹,用新的空文件夹加上原始的文件名拼接成新的路径然后写入进去

  下面上代码:

  importos

  #初始的文件夹路径

  filePath="/Users/xxxxxxxx/Desktop/fileDocument"

  #存放新文件的空白文件夹

  newFilePath="/Users/xxxxxxxx/Desktop/newFileDocument"

  #获取文件夹下所有文件名

  fileNames=os.listdir(filePath)

  forfileinfileNames:

  #如果当前的文件名包含了'txt',就当它是正确的文件(并不严谨)

  iffile.find("txt")>=0:

  #拼接成我们要读取的完整路径

  fileFullPath=filePath+"/"+file

  #open函数默认是'r'类型,

  singleFile=open(fileFullPath)

  #转换成list数据

  singleFile_list=singleFile.readlines()

  tempIndex=0

  forindexinrange(len(singleFile_list)):

  temp=singleFile_list[index]

  result=temp.find("min")==0

  ifresult:

  tempIndex=index

  break

  #拼接新的文件路径

  newSingleFileFullPath=newFilePath+"/"+file

  #以w方式打开新的空白文件

  newFile=open(newSingleFileFullPath,'w')

  forindexinrange(len(singleFile_list)):

  ifindex>tempIndex:

  #写入tempindex行之后的数据

  newFile.writelines(singleFile_list[index])

  newFile.close()

  上面的代码其实没啥要介绍的,就是一个for循环然后逻辑和单个文件读操作一样,只是多了个写操作。

  这只是自己因缘巧合写的一些简单的实现,并没有去系统的学习Python,好多API不了解,可能这种处理不是很好,没注重性能,没多线程。等以后深入学习了再优化。

  以上就是关于扣丁学堂Python培训之文件读写保存操作示例代码的全部内容,希望对大家的学习有所帮助,扣丁学堂IT职业在线学习教育平台为您提供从入门到精通Python视频视频让你快速掌握Python开发实战技能。扣丁学堂Python技术交流群:279521237。

  ?扣丁学堂微信公众号

  【关注微信公众号获取更多学习资料】

  查看更多关于"Python开发资讯"的相关文章>?

相关文章

网友评论

    本文标题:扣丁学堂Python培训之文件读写保存操作示例代码详解

    本文链接:https://www.haomeiwen.com/subject/lbiknftx.html