本文实例讲述了Python打开文件、文件读写操作、with方式、文件常用函数。分享给大家供大家参考,具体如下:
打开文件:
在python3中,打开文件的函数是:
1
|
<strong> open ( file , mode = 'r' , buffering = None , encoding = None , errors = None , newline = None , closefd = True )< / strong>
|
参数说明:
1
|
file - - 文件名
|
1
|
mode—打开模式,默认只读模式
|
1
|
buffering - - 如果buffering的值被设为 0 ,就不会有寄存。如果buffering的值取 1 ,访问文件时会寄存行。如果将buffering的值设为大于 1 的整数,表明了这就是的寄存区的缓冲大小。如果取负值,寄存区的缓冲大小则为系统默认。
|
1
|
encoding—打开文件的编码方式
|
模式介绍:
r:只读模式(默认)
w :只写模式,如果文件不存在就创建,如果存在,写入的数据会覆盖原来的数据
b :二进制模式
t :文本模式
+:可写可读模式
a:追加模式,如果文件存在则文件指针指向文件末尾(追加数据),如果不存在就创建
r+:读追加模式,先读,再追加
w+:写读模式,先写,意味着原本内容丢失,再读。
- 如果对于含有非ascll字符的文件,必须使用encoding,否则会抛异常:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
print ( "r" .center( 50 , '-' ))
f = open ( "file.txt" ,encoding = "utf-8" )
print (f.read())
f.close()
- - - - - - - - - - - - - - - - -
运行结果:
my
sas
aaa
fsafsa
中文
中文
葫芦娃
|
文件使用完毕后必须关闭: 文件指针.close()
文件操作:
读操作:
读取文件内容如下:
- reads()是读出全部内容
1
2
3
4
5
6
7
8
9
10
11
12
13
|
print ( "r" .center( 50 , '-' ))
f = open ( "file.txt" ,encoding = "utf-8" )
print (f.read())
f.close()
- - - - - - - - - - - - - - - - - - - - - - - - - - -
运行结果:
my
sas
aaa
fsafsa
中文
中文
葫芦娃
|
- readline()是读出一行
1
2
3
4
5
6
7
8
|
print ( "r" .center( 50 , '-' ))
f = open ( "file.txt" ,encoding = "utf-8" )
print (f.readline())
f.close()
- - - - - - - - - - -
运行结果:
my
|
- readlines()是读出全部内容,并整理成一个列表
1
2
3
4
5
6
7
8
9
10
11
|
print ( "r" .center( 50 , '-' ))
f = open ( "file.txt" ,encoding = "utf-8" )
print (f.readlines())
f.close()
#------------------------r-------------------------
#运行结果:
[ 'my\n' , 'sas\n' , 'aaa\n' , 'fsafsa\n' , '中文\n' , '中文\n' , '葫芦娃\n' , '\n' ]
|
- r+模式会根据读的内容来决定指针的位置
1
2
3
4
5
|
print ( "r" .center( 50 , '-' ))
f = open ( "file.txt" , "r+" ,encoding = "utf-8" )
# print(f.readline())
f.write( "hello mike" )
f.close()
|
结果:
1
2
3
4
5
|
print ( "r" .center( 50 , '-' ))
f = open ( "file.txt" , "r+" ,encoding = "utf-8" )
print (f.readline())
f.write( "hello mike" )
f.close()
|
新结果:
写操作:
- write():将一个字符串写入文件
1
2
3
4
|
myfile = open ( "myfile1" , "wb" )
myfile.write(b "nnnnnn" )
myfile.write( "my葫芦娃" .encode( "utf-8" ))
myfile.close()
|
- writelines(可迭代对象) 将一个可迭代对象写入文件
1
2
3
4
5
|
myfile = open ( "myfile1" , "wb" )
myfile.write(b "nnnnnn" )
myfile.writelines([b '1' ,b '2' ,b '3' ,b '4' ])
myfile.close()
|
- 当需要写完之后即时读出来时,使用w+,然后将文件指针置回文件头:
1
2
3
4
5
|
myfile = open ( "myfile1" , "wb+" )
myfile.write(b "nnnnnn" )
myfile.seek( 0 )
print (myfile.read())
myfile.close()
|
-
-
- 如果是需要读出特定位置,可以使用变量来记录位置
-
1
2
3
4
5
6
7
|
myfile = open ( "myfile1" , "wb+" )
myfile.write(b "1nnnnnn" )
site = myfile.tell()
myfile.write(b "2nnnnnn" )
myfile.seek(site) ##读出后一段
print (myfile.read())
myfile.close()
|
with:
- 为了便捷的关闭文件,python增加了with功能,当with体执行完将自动关闭打开的文件:
1
2
3
4
5
|
with open ( "file.txt" , "r+" ,encoding = "utf-8" ) as f: ##将自动执行f.close()
print (f.tell())
f.write( "金刚" )
for line in f:
print (line,end = "")
|
- 可以同时打开多个文件:
1
2
3
|
with open ( "file.txt" , 'r' ) as f ,\
open ( "file.new" , 'r' ) as m:
print (f.read(),m.read())
|
文件常用函数:
file.close():关闭文件。关闭后文件不能再进行读写操作
file.seek(offset[, whence]):设置文件当前位置
file.tell():返回文件当前位置。
1
2
3
4
5
6
7
|
myfile = open ( "myfile1" , "wb+" )
myfile.write(b "1nnnnnn" )
site = myfile.tell()
myfile.write(b "2nnnnnn" )
myfile.seek(site) ##读出后一段
print (myfile.read())
myfile.close()
|
file.flush():刷新文件内部缓冲,立即把内部缓冲区的数据写入文件,因为并不是马上将文件
1
2
3
4
5
6
7
|
import time
myfile = open ( "myfile1" , "wb+" )
myfile.write(b "1nnnnnn" )
time.sleep( 10 )
# myfile.flush()
myfile.write(b "2nnnnnn" )
myfile.close()
|
上述代码,直到程序运行完成才一次性写入“1nnnnnn2nnnnnn”
1
2
3
4
5
6
7
|
import time
myfile = open ( "myfile1" , "wb+" )
myfile.write(b "1nnnnnn" )
myfile.flush()
time.sleep( 10 )
myfile.write(b "2nnnnnn" )
myfile.close()
|
上述代码,可以看到,在程序sleep之前就已经写入了“1nnnnnn”
file.truncate([size]):截取文件,从文件开头,截到指定位置,会覆盖原文件。
文件内容:
1
2
3
4
5
6
7
8
9
|
print ( "r" .center( 50 , '-' ))
f = open ( "file.txt" , "r+" ,encoding = "utf-8" )
print (f.readline())
print ( "----truncate()-------" )
print (f.tell())
m = f.tell()
f.truncate(m) #内容从0位置截断到指定位置,不论当前光标位置
f.close()
|
执行后,文件内容:
希望本文所述对大家Python程序设计有所帮助。
原文链接:https://www.cnblogs.com/progor/p/8412953.html