python学习——python中的文件处理

简介:

python对文件的处理。

python对文件的处理的两个内建函数:

open()、file(),这个两函数提供了初始化输入\输出(I\O)操作的通用接口。两函数的功能相同。

基本用法:

file_object=open(filename, access_mode='r', buffering=-1)

file_object 是定义一个打开文件的对象

access_mode 是打开文件的模式;通常,文件使用模式 'r','w','a' 来打开,分别代表,读取,写入,追加。

'r' 模式打开已经存在的文件

'w' 模式打开的文件若存在则首先清空,再加入内容。

'a' 这个模式是追加内容到文件中

注. 'b' 模式这个是打开二进制文件,对于unix-like/unix类型的系统'b'模式是可有可无的。

buffering 访问文件所采用的缓冲方式。其中0表示不缓冲,1表示只缓冲一行数据,任何其它大于1的值代表使用给定的值作为缓冲区大小。不给定此参数或者参数为负数都表示使用系统默认的缓冲机制。


常用的文件访问方式如下:

r        以读方式打开

rU或Ua   以读方式打开同时提供通用换行符支持

w        以写方式打开

a        以追加方式打开

r+       以读写方式打开

w+       以读写方式打开

a+       以读写方式打开


文件的输入:

python中有三个方法来处理文件内容的输入:

read() 一次读取全部的文件内容。

readline() 每次读取文件的一行。

readlines() 读取文件的所有行,返回一个字符串列表。


分别举例说明一下:

read():

1
2
3
4
5
6
7
8
>>> f = open ( 'f.sh' )
>>> ff = f.read()    #以read()方法取得文件全部内容。
>>>  print  ff
#!/bin/bash
for  in  {a,test,bak};do
     echo $i
done
>>>


readline():

1
2
3
4
5
>>> f = open ( 'f.sh' )
>>>  file = f.readline()
>>>  print  file
#!/bin/bash
>>>

每次打印都会显示出文件内容的第一行,如要显示文件的所有内容,则加一个while循环。如下所示:

1
2
3
4
5
6
7
8
9
10
11
>>>  while  1 :
...      file  =  f.readline()
...      if  file :
...              print  file
...      else :
...              break
...
for  in  {a,test,bak};do
     echo $i
done
>>>

这样就显示出文件的所有内容了。

readlines():

1
2
3
4
>>> f = open ( 'f.sh' )
>>>  file = f.readlines()
>>>  print  file
[ '#!/bin/bash \n' 'for i in {a,test,bak};do\n' '\techo $i\n' 'done\n' ]   #文件内容以字符串列表的形式显示出来。

如果要正常的显示出文件来可以用eachLine这个参数,此参数代表文本文件的一行(包括末尾的换行符)

1
2
3
4
5
6
7
8
9
10
11
>>>  for  eachLine  in  file :
...      if  eachLine:
...              print  eachLine
...      else :
...              print  "failed"
...
#!/bin/bash
for  in  {a,test,bak};do
     echo $i
done
>>>

也可以这样来读取文件内容:

1
2
3
4
5
6
7
8
9
10
11
12
>>> f = open ( 'f.sh' )
>>>  file  =  f.readlines()
>>>  print  file
[ '#!/bin/bash \n' 'for i in {a,test,bak};do\n' '\techo $i\n' 'done\n' ]
>>>  for  in  range ( len ( file )):
...      print  file [i]
...
#!/bin/bash
for  in  {a,test,bak};do
     echo $i
done
>>>

下面来说一下文本文件的输出 write.先看一下例子:

1
2
3
4
5
6
7
8
9
10
>>> f = open ( 'a' 'w' )
>>> s  =  'This is a new line.'
>>> f.write(s)
>>> f.close()
来读取一下这个刚创建的文件
>>> f = open ( 'a' )
>>>  file = f.read()
>>>  print  file
This  is  a new line.
>>>

再来说一下python中在文本文件内容移动的操作,主要是用到seek()这个函数。以例子说明一下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
>>> f  =  open ( 'a' 'w+' )       #'w+' 表示,文件以可读可写模式打开。
>>> f.tell()                 #用tell()方法来记录打开文件的位置。初始的位置0
0
>>> f.write( 'test line 1\n' #向文件中写入新的一行。
>>> f.tell()
12                            #显示出移动的位置。
>>> f.write( 'test line 2\n' #再向文件中加入新的一行。
>>> f.tell()
24                            #显示出移动的位置。
>>> f.seek( - 12 , 1 )             #向后移动12个字节的位置。应该移动到文件内容的第二行的开头
>>> f.tell()
12
>>> f.readline()              #用readline()方法读取当前位置时的文件内容。
'test line 2\n'               #显示的是文件的第二行,可见readline()方法读取的是当前位置以后的内容。
>>> f.seek( 0 , 0 )               #回到文件的开始位置
>>> f.readline() 
'test line 1\n'               # 显示文件的第一行。
>>> f.tell()
12                            #此时位置在第二行的开始处。
>>> f.readline()
'test line 2\n'
>>> f.tell()
24                            #此时又到了文件第三行的开始处了。
>>> f.close()


这里只是记录了python处理文本文件的简单运行方法,python对文件的处理还有很多特性,需要进一步的学习和运用。。。。^_^




本文转自 ZhouLS 51CTO博客,原文链接:http://blog.51cto.com/zhou123/1281393


相关文章
|
2月前
|
机器学习/深度学习 Python
堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能
本文深入探讨了堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能。文章详细介绍了堆叠的实现步骤,包括数据准备、基础模型训练、新训练集构建及元学习器训练,并讨论了其优缺点。
64 3
|
2月前
|
安全 关系型数据库 测试技术
学习Python Web开发的安全测试需要具备哪些知识?
学习Python Web开发的安全测试需要具备哪些知识?
36 4
|
3月前
|
PyTorch Linux 算法框架/工具
pytorch学习一:Anaconda下载、安装、配置环境变量。anaconda创建多版本python环境。安装 pytorch。
这篇文章是关于如何使用Anaconda进行Python环境管理,包括下载、安装、配置环境变量、创建多版本Python环境、安装PyTorch以及使用Jupyter Notebook的详细指南。
370 1
pytorch学习一:Anaconda下载、安装、配置环境变量。anaconda创建多版本python环境。安装 pytorch。
|
17天前
|
Python 容器
Python学习的自我理解和想法(9)
这是我在B站跟随千锋教育学习Python的第9天,主要学习了赋值、浅拷贝和深拷贝的概念及其底层逻辑。由于开学时间紧张,内容较为简略,但希望能帮助理解这些重要概念。赋值是创建引用,浅拷贝创建新容器但元素仍引用原对象,深拷贝则创建完全独立的新对象。希望对大家有所帮助,欢迎讨论。
|
8天前
|
Python
Python学习的自我理解和想法(10)
这是我在千锋教育B站课程学习Python的第10天笔记,主要学习了函数的相关知识。内容包括函数的定义、组成、命名、参数分类(必须参数、关键字参数、默认参数、不定长参数)及调用注意事项。由于开学时间有限,记录较为简略,望谅解。通过学习,我理解了函数可以封装常用功能,简化代码并便于维护。若有不当之处,欢迎指正。
|
19天前
|
存储 索引 Python
Python学习的自我理解和想法(6)
这是我在B站千锋教育学习Python的第6天笔记,主要学习了字典的使用方法,包括字典的基本概念、访问、修改、添加、删除元素,以及获取字典信息、遍历字典和合并字典等内容。开学后时间有限,内容较为简略,敬请谅解。
|
23天前
|
存储 程序员 Python
Python学习的自我理解和想法(2)
今日学习Python第二天,重点掌握字符串操作。内容涵盖字符串介绍、切片、长度统计、子串计数、大小写转换及查找位置等。通过B站黑马程序员课程跟随老师实践,非原创代码,旨在巩固基础知识与技能。
|
22天前
|
程序员 Python
Python学习的自我理解和想法(3)
这是学习Python第三天的内容总结,主要围绕字符串操作展开,包括字符串的提取、分割、合并、替换、判断、编码及格式化输出等,通过B站黑马程序员课程跟随老师实践,非原创代码。
|
19天前
|
Python
Python学习的自我理解和想法(7)
学的是b站的课程(千锋教育),跟老师写程序,不是自创的代码! 今天是学Python的第七天,学的内容是集合。开学了,时间不多,写得不多,见谅。
|
18天前
|
存储 安全 索引
Python学习的自我理解和想法(8)
这是我在B站千锋教育学习Python的第8天,主要内容是元组。元组是一种不可变的序列数据类型,用于存储一组有序的元素。本文介绍了元组的基本操作,包括创建、访问、合并、切片、遍历等,并总结了元组的主要特点,如不可变性、有序性和可作为字典的键。由于开学时间紧张,内容较为简略,望见谅。