python之文件的基本操作

简介:
1
2
#encoding=utf-8
#author:zhouyu

os这个模块是用来对系统文件的一些基本操作的,比较创建文件,修改文件以及删除文件。

文件的基本操作有以下几种:

1
2
3
4
5
6
7
8
9
10
r,以只读的形式打开文件
w,以只写的形式打开这个文件,如果这个文件存在就覆盖这个文件来写东西,否则创建文件
a,在文件后面加上你想加的内容,也就是append
rb,以只读的形式打开一个二进制文件
wb,以只写的形式打开一个二进制文件,如果这个文件存在就覆盖这个文件来写东西,否则创建文件
ab,在一个二进制文件后面加上你想加的内容,也就是append
r + ,以读写的形式打开一个文件,如果这个文件不存在会报错
w + ,以读写的形式打开一个文件,如果这个文件存在可以覆盖这个文件来写东西,否则创建文件
a + ,以读写的形式打开文件可以在文件后面加上你想加的内容,也就是append
rb + ,wb + 和ab + 我就不解释了

一般来说,如果你想获取这个文件的内容或者你想修改文件的信息,就必须要先打开文件。

1
2
3
4
5
import  os    #导入os模块
test_file  =  'C:\\test.txt'
opentest  =  open (test_file, 'r' )   #以只读的形式打开文件
read_test  =  opentest.read()    #把文件内容储存在opentest变量
print (read_test)

不管阅读什么文件,Python阅读时候有个光标,它是用来记录你读取到哪里的一个虚体,

等你下次来读取文件的时候,就会从这个光标开始读起,除非你关闭文件重新打开这个文件,

 或者你把这个光标调到你想开始读取的地方,因为上面我们把这个文件读完了,你现在再读

的话就阅读不了,因为光标在最后了。

1
2
3
print ( "now I want to continue read above file" )
read_test1  =  opentest.read()
print (read_test1)

现在我们可以看看这个光标在哪里

1
print (opentest.tell())

打印出来的结果是91,这就可以说明光标是在第91个字符那里,如果你想重新阅读这个文件,

 可以通过以下命令来调整光标

1
print (opentest.seek( 0 ))

再让读这个文件把内容给read_test1变量

1
read_test1  =  opentest.read()

这样你就又把你的光标调为0了,下面我们再打印我们阅读的文件

1
print (read_test1)

python是比较笨的,上面写了只读,它就不能写文件,如果你把以下代码的#去掉就会报错

1
opentest.write( "this is test" )

记住每次用完文件都要关闭文件。以下代码是关闭文件

1
opentest.close()

下面是写的操作,不过一般不推荐这个,因为你用w的话python会创建一个文件,如果这个文件

存在,它就会把这个文件覆盖,也就是说文件的内容会被清空,这是很危险的

1
2
3
opentest  =  open (test_file, 'w' )
opentest.write( "you will found your file'content be clear,and rewrite this!!!" )
opentest.close()

如果你不想这样,只想在文件最后添加内容的话可以通过以下方法:

1
2
3
opentest  =  open (test_file, 'a' )
opentest.write( "\nthis is append statement !!!" )
opentest.close()

执行完这个你可以去看看你的文件里面是不是有增加上面的内容

如果我只想看看前5行的内容怎么办呢,其实有两种方法,不过你的文件一定要有5行

下面这种是最高效的

1
2
3
4
5
6
7
8
count  =  0
test_file  =  'C:\\test.txt'
opentest  =  open (test_file, 'r' )
for  in  opentest:
     if  count < =  5 :
         count  = + 1
         print (i)
opentest.close()

下面这种是相对比较低效的

1
2
3
4
5
6
7
8
count  =  0
test_file  =  'C:\\test.txt'
opentest  =  open (test_file, 'r' )
for  in  range ( 5 ):
     if  count < =  5 :
         count  = + 1
         print (opentest.readline())
opentest.close()

为什么它们会有高低效之分呢,是因为第一种是利用迭代器,每次只在文件里面取

一条数据,用完就删除这个数据,而第二种是把文件里面所有的内容都取出来,如

果你的文件有20G,那你就要等很久,而且你的内存一下子放20G也不大可能,所以

一般都用第一种高效方法


本文转自 周子琪 51CTO博客,原文链接:http://blog.51cto.com/izhouyu/1965087

相关文章
|
24天前
|
Python
【python】python跨文件使用全局变量
【python】python跨文件使用全局变量
|
1月前
|
监控 数据处理 索引
使用Python批量实现文件夹下所有Excel文件的第二张表合并
使用Python和pandas批量合并文件夹中所有Excel文件的第二张表,通过os库遍历文件,pandas的read_excel读取表,concat函数合并数据。主要步骤包括:1) 遍历获取Excel文件,2) 读取第二张表,3) 合并所有表格,最后将结果保存为新的Excel文件。注意文件路径、表格结构一致性及异常处理。可扩展为动态指定合并表、优化性能、日志记录等功能。适合数据处理初学者提升自动化处理技能。
23 1
|
1月前
|
存储 并行计算 Java
Python读取.nc文件的方法与技术详解
本文介绍了Python中读取.nc(NetCDF)文件的两种方法:使用netCDF4和xarray库。netCDF4库通过`Dataset`函数打开文件,`variables`属性获取变量,再通过字典键读取数据。xarray库利用`open_dataset`打开文件,直接通过变量名访问数据。文中还涉及性能优化,如分块读取、使用Dask进行并行计算以及仅加载所需变量。注意文件路径、变量命名和数据类型,读取后记得关闭文件(netCDF4需显式关闭)。随着科学数据的增长,掌握高效处理.nc文件的技能至关重要。
153 0
|
1月前
|
BI 数据处理 索引
Pandas基本操作:Series和DataFrame(Python)
Pandas基本操作:Series和DataFrame(Python)
105 1
|
1月前
|
Python
python中文件和异常处理方法(二)
python中文件和异常处理方法(二)
13 0
|
1月前
|
Python
python中文件和异常处理方法(一)
python中文件和异常处理方法(一)
29 0
|
1月前
|
Python
python中文件和异常处理方法(三)
python中文件和异常处理方法(三)
20 0
|
1天前
|
JSON JavaScript 数据格式
python遍历目录文件_结合vue获取所有的html文件并且展示
python遍历目录文件_结合vue获取所有的html文件并且展示
4 0
|
8天前
|
存储 Python
用Python实现批量下载文件——代理ip排除万难
用Python实现批量下载文件——代理ip排除万难
|
8天前
|
JSON 关系型数据库 数据库
《Python 简易速速上手小册》第6章:Python 文件和数据持久化(2024 最新版)
《Python 简易速速上手小册》第6章:Python 文件和数据持久化(2024 最新版)
37 0