文件的打开
open函数
在python中,使用open函数,打开一个已经存在的文件,或者新建一个新文件
open(name,mode,buffering,encoding)
name:一个包含了要访问的文件名称的字符串值(区分绝对路径和相对路径)
非强制的,默认文件访问模式为只读(r)
buffering : 如果 buffering 的值被设为 0,就不会有寄存;如果 buffering 的值取 1,访问文件时会寄存行;如果将 buffering 的值设为大于 1 的整数,表明了这就是的寄存区的缓冲大小;如果取负值,寄存区的缓冲大小则为系统默认
encoding= 'utf-8'这一句,避免显示乱码
with…open
关键字with在不再需要访问文件后将其关闭,换言之就是不用写close()语句;你只管打开文件,并在需要时使用它,Python自会在合适的时候自动将其关闭;也可以调用open()和close()来打开和关闭文件,但这样做时,如果程序存在bug,导致close()语句未执行,文件将不会关闭
with open('python.txt','r',encoding= 'utf-8' ) as files:
contnet = files.read() #注意缩进
print(contnet) #输出为 SKT的中单是Faker;SKT的打野是Bengi
关闭文件
对于文件的操作结束之后,使用close()来关闭文件
文件对象.close()
#打开文件
files = open('python.txt','r',encoding= 'utf-8' )
#读取文件内容
content = files.read(13) #传入参数会读取指定的长度
print(content) #输出为 SKT的中单是Faker;
content = files.read() #读取数据保存在content变量当中
#输出读取的内容,read()读取到的是光标以后的所有数据
print(content) #输出为 SKT的打野是Bengi
#关闭文件
files.close()
文件读取
read(num):可以读取文件里面的内容;num表示要从文件中读取的数据的长度(单位是字节),如果没有传入num,那么就表示读取文件中所有的数据
readlines:可以按照行的方式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素
注意:读取文本文件时,Python将其中的所有文本都解读为字符串,如果读取的是数字,并要将其作为数值使用,就必须使用函数int()将其转换为整数,或使用函数float()将其转换为浮点数
files = open('python.txt','r',encoding= 'utf-8' )
content = files.readlines()
print(content) #输出为 ['SKT的中单是Faker;\n', 'SKT的打野是Bengi']
files.close()
with open('python.txt','r',encoding= 'utf-8' ) as files:
contnet = files.readlines() #按行读取文件内容,保存在列表当中
print(contnet) #输出为 ['SKT的中单是Faker;\n', 'SKT的打野是Bengi']
文件的读取与循环操作
'''
输出为 这是第1行内容:SKT的中单是Faker;
这是第2行内容:SKT的打野是Bengi
'''
# 用open结合for循环逐行读取
files = open('python.txt','r',encoding= 'utf-8')
i = 1
for line in files:
#没有使用read
print('这是第%d行内容:%s'%(i,line))
i+=1
files.close()
# 用with结合for循环逐行读取 (两种不同方式,结果一样)
with open('python.txt','r',encoding= 'utf-8') as files:
i = 1
for line in files:
#没有使用read
print('这是第%d行内容:%s'%(i,line))
i+=1
# 用open结合for,readlines循环逐行读取,注意这里的循环操作是在文件操作外执行的
files = open('python.txt','r',encoding= 'utf-8')
contents = files.readlines()#逐行读取内容
files.close()#关闭文件
i = 1
for line in contents:
#没有使用read
print('这是第%d行内容:%s'%(i,line))
i+=1
files.close()
with open('python.txt','r',encoding= 'utf-8') as files:
contents = files.readlines()
i = 1
for line in contents:
#没有使用read
print('这是第%d行内容:%s'%(i,line))
i+=1
文件写入
需要手动添加\n
注意:Python只能将字符串写入文本文件,要将数值数据存储到文本文件中,必须先使用函数str()将其转换为字符串格式
'''
python.txt文件里的内容变为:
SKT的ADC是Bang;SKT的辅助是Wolf
SKT加油啊
'''
#以写的方式打开一个文件
files = open('python.txt','w',encoding='utf-8')
content = 'SKT的ADC是Bang;'
files.write(content) #写入数据
files = open('python.txt','a',encoding='utf-8')
content = 'SKT的辅助是Wolf'
files.write(content) #写入数据
files.close()
with open('python.txt','a',encoding='utf-8') as files:
content = '\nSKT加油啊' # \n表示换行
files.write(content)
常用函数
1、tell查看文件指针
'''
1、文件打开方式为文本模式时,代表读取3个字符
2、文件打开方式为b模式时,代表读取3个字节
输出为
当前读取的数据是:SKT的ADC是Bang;
当前的位置是: 19
当前读取的数据是:SKT的辅助是Wolf
SKT加油啊
当前的位置是: 52
'''
files = open('python.txt','r',encoding='utf-8')
str = files.read(13)
print('当前读取的数据是:'+str)
#查看文件的指针
position = files.tell()
print('当前的位置是:',position)
str = files.read()
print('当前读取的数据是:'+str)
#查看文件的指针
position = files.tell()
print('当前的位置是:',position)
files.close()
2、seek 设置指针
'''
输出为
当前读取的数据是:SKT的ADC是Bang;
当前的位置是: 19
当前读取的数据是:ADC
当前的位置是: 9
'''
files = open('python.txt','r',encoding='utf-8')
str = files.read(13)
print('当前读取的数据是:'+str)
# 查看文件的指针
position = files.tell()
print('当前的位置是:',position)
# 重新设置文件的指针
files.seek(6,0) #一个汉字代表三个字符
str = files.read(3)
print('当前读取的数据是:'+str)
# #查看文件的指针
position = files.tell()
print('当前的位置是:',position)
files.close()