澳门新萄京官方网站-www.8455.com-澳门新萄京赌场网址

澳门新萄京官方网站:Python文件处理,学习笔记

2019-12-01 作者:www.8455.com   |   浏览(128)

文件

Python文件处理,

本文给大家介绍Python文件处理相关知识,具体内容如下所示:

1.文件的常见操作

文件是日常编程中常用的操作,通常用于存储数据或应用系统的参数。python提供了os、os.path、shutil等模块处理文件,其中包括最常用的打开文件,读写文件,赋值文件和删除文件等函数。

1.1文件的创建

python3. 中移除了python2中的全局file()函数,还保留了open()函数。文件的打开或创建可以使用函数open()。该函数可以指定处理模式,设置打开的文件为只读,只写,可读写状态。open()的声明如下:

open(file, mode='r', buffering=None, encoding=None, errors=None, newline=None, closefd=True)

参数说明:

•参数file是被打开的文件名称,如果文件file不存在,open()将创建名为name的文件,然后再打开该文件。

•参数mode是指文件的打开模式。文件的打开模式请参照以下内容。

•参数buffering是设置缓存模式。0表示不缓存,1表示缓存;如果大于1则表示缓冲区的大小,以字节为单位。

•参数encoding是设置文件的字符编码格式。

•open()函数会返回一个file对象,file 对象可以对文件进行各种操作 文件模式:

'r' open for reading (default)
'w' open for writing, truncating the file first
'x' create a new file and open it for writing

创建一个新的文件,打开并写入

'a' open for writing, appending to the end of the file if it exists

模式打开文件以追加

'b' binary mode二进制模式打开,可与其他模式一起使用
't' text mode (default)
' ' open a disk file for updating (reading and writing)
'U' universal newline mode (deprecated)支持所有的换行符号

注意:图片、视频等文件必须使用b的模式进行读写。

message = '''
hello world,n
hello python,n
good time.
'''
f = open('test.txt','w')
f.write(message)
f.close()

代码说明:

•定义一个字符串变量

•以只写模式创建一个文件并写入

•将字符串变量写入文件

•关闭文件

1.2 文件的读取

文件的读取有多种方法,可以使用readline()、readlines()、或read()函数读取文件。

1.按行读取方式readline()

readline()每次读取文件的一行,需要循环读取文件。但是当文件指针移动到文件的末尾是,依然使用readline()读取文件将出现错误。因此程序中需要添加一个判断语句,判断时间指针是否在文件的尾部,并且通过该语句中断循环。示例如下:

# 使用readline模式读取文件
f = open('test.txt','r')
while True:
line = f.readline()
if line:
print(line)
else:
break
f.close()
#如果line = f.readline(2)则表示每次循环只读取两字节的内容,直到行的末尾

2.多行读取方式readlines()

# 多行读取文件
f = open('test.txt')
lines = f.readlines()
for line in lines:
print(line)
f.close()

3.一次性读取方式read()

读取文件最简单的方式就是使用read(),read()将文件中一次性读出所有内容,并赋值给字符串变量,但是当文件比较大的时候不建议使用read()的方式去读取文件,因为一次读取比较大的内容会消耗大量的内存,影响系统的性能。示例如下:

# 一次读取文件
f = open('test.txt','r')
lines = f.read()
print(lines)
f.close()

文件指针:

with open('test.txt','rb') as src:
rd = src.read(100)
print(rd)
print(src.seek(src.tell()))
rd = src.read(100)
print(rd)
print(src.seek(src.tell()))
#每次读取100字节,然后返回指针的位置

4.with函数

通常我们使用open()打开一个文件并赋值给一个字符串变量来对文件进行操作,最后还需要进行手动关闭文件,这样写起来有点麻烦,下面我们可以使用with函数将文件打开与关闭写在一行函数上。

with open('test.txt','r') as src:
da = src.read()
print(da)
#只读模式打开文件并赋值给src,然后对文件进行操作即可,代码与使用open()来操作文件相同。

1.3文件的写入

文件的写入有多种方法,可以使用write(),也可以使用writelines()方法写入文件。write()可以将字符串写入文件,writelines()可以将列表写入文件。示例如下:

m1 = 'hello world'
l1 = ['good','time']
f = open('test1.txt','w')
f.write(m1)
f.writelines(l1)
f.close()

文件的追加:

m1 = 'hello python'
f = open('test1.txt','a ')
f.write(m1)
f.close()

1.4文件的删除

文件的删除需要使用os模块和os.path模块,os模块提供了系统的环境、文件、目录等操作系统的函数。 对于文件来说比较常用的os模块的函数如下:

•os.access(path,mode)#按照mode指定的权限进行访问
•os.chmod(path,mode)#改变文件的访问权限,mode用UNIX的权限符号表示
•os.open(filename,flag[,mode=0777])#按照mode指定的权限打开文件。默认情况下,给所有用户读、写、执行的权限
•os.remove(path)#删除path指定的文件
•os.rename(old,new)#重命名文件或目录,old表示原文件或目录,new表示新文件或目录
•os.stat(path)#返回path指定文件的所有属性
•os.fstat(path)#返回打开文件的所有属性
•os.startfile(filepath[,operation])#启动关联程序打开文件。例如,打开一个html文件,将启动IE浏览器
•os.tmpfile()#创建一个临时文件,文件创建在操作系统的临时目录中

注意:os模块的open()函数与内建的open()函数的用法不同。

os.path模块常用的函数如下:

•os.path.abspath(path)#返回path所在的绝对路径
•os.path.dirpath(path)#返回目录的路径
•os.path.exists(path)#判断文件是否存在
•os.path.getatime(filename)#返回文件的最后访问时间
•os.path.getctime(filename)#返回文件的创建时间
•os.path.getmtime(filename)#返回文件最后的修改时间
•os.path.getsize(filename)#返回文件的大小

os.path判断函数

•os.path.isabs(s)#测试路径是否是绝对路径
•os.path.isdir(path)#判断path指定的是否是目录
•os.path.isfile(path)#判断path指定的是否是文件
•os.path.split(p)#对路径进行分割,并以列表的方式返回
•os.path.splitext(p)#从路径中分割文件的扩展名
•os.path.splitdrive(p)#从路径中分割驱动器的名称
•os.walk(top,func,arg)#遍历目录树

示例如下:

import os
if os.path.exists('../test.txt'):
os.remove('test.txt')
print('is del')
else:
print('no')

1.5文件的复制

文件的复制有多种方法,下面我们来看一下第一种比较low的方式,就是读写的方式进行文件复制。示例如下:

#使用read()、write()实现文件复制
f1 = open('1.txt','r')
f2 = open('2.txt','w')
f2.write(f1.read())
f2.close()
f1.close()

第二种方法:

shutil模块,shutil模块是另外一个文件、目录的管理接口,提供了一些用于复制、目录的函数。copyfile()函数可以实现文件的复制,copyfile()函数的声明如下:
shuil.copyfile(src,dst)
•src表示源文件的路径,src是字符串类型
•dst表示目标文件的路径,dst是字符串类型
•src指向的文件复制到dst指向的文件

示例如下:

import shutil
shutil.move('1.txt','2.txt')

1.6文件的重命名

os模块的函数rename()可以对文件或目录进行重命名。

import os
os.rename('1.txt','11.txt')

使用shutil中的move()函数也可以实现文件重命名的目的。

import shutil
shutil.move('11.txt','1.txt')

修改文件的后缀名:

import os
files = os.listdir('.')
for filename in files:
li = os.path.splitext(filename)#返回后文件名和后缀名的列表
if li[1] == '.html':
newname = li[0]   '.htm'
os.rename(filename,newname)

glob模块用于对路径的匹配,返回符合给定条件的文件列表。glob模块的主要函数就是glob(),该函数返回符合同一匹配条件的多个文件。上面的呈现需要判断是否为html后缀,也可以使用glob()函数直接匹配文件名称。 匹配代码如下:

glob.glob('*.html')

glob还可以对路径做更对的匹配。例如,匹配C盘中以w开头的目录中所有的文本文件。

glob.glob('C:\w*\*\txt') 

1.7文件的搜索和替换

文件内容的搜索和替换可以使用字符串的查找和替换来实现。例如,在htllo.txt文件中查找字符串'hello',并统计'hello'出现的次数。代码如下:

python, equal to anything!

以上内容给大家介绍了Python文件处理相关知识,希望对大家有所帮助!

From:

python之文件的读写和文件目录以及文件夹的操作实现代码,

为了安全起见,最好还是给打开的文件对象指定一个名字,这样在完成操作之后可以迅速关闭文件,防止一些无用的文件对象占用内存。举个例子,对文本文件读取:

file_object = open('thefile.txt') 
try: 
all_the_text = file_object.read( ) 
finally: 
file_object.close( )

Python读写文件实际操作的五大步骤
一、打开文件
Python读写文件在计算机语言中被广泛的应用,如果你想了解其应用的程序,以下的文章会给你详细的介绍相关内容,会你在以后的学习的过程中有所帮助,下面我们就详细介绍其应用程序。
代码如下:

f = open("d:test.txt", "w") 

说明:
第一个参数是文件名称,包括路径;第二个参数是打开的模式mode
'r':只读(缺省。如果文件不存在,则抛出错误)
'w':只写(如果文件不存在,则自动创建文件)
'a':附加到文件末尾
'r ':读写
如果需要以二进制方式打开文件,需要在mode后面加上字符"b",比如"rb""wb"等
二、读取内容
f.read(size)
参数size表示读取的数量,可以省略。如果省略size参数,则表示读取文件所有内容。
f.readline()
读取文件一行的内容
f.readlines()
读取所有的行到数组里面[line1,line2,...lineN]。在避免将所有文件内容加载到内存中,这种方法常常使用,便于提高效率。
三、写入文件

f.write(string)
将一个字符串写入文件,如果写入结束,必须在字符串后面加上"n",然后f.close()关闭文件

四、文件中的内容定位
澳门新萄京官方网站,f.read()
读取之后,文件指针到达文件的末尾,如果再来一次f.read()将会发现读取的是空内容,如果想再次读取全部内容,必须将定位指针移动到文件开始:
f.seek(0)
这个函数的格式如下(单位是bytes):
f.seek(offset, from_what)
from_what表示开始读取的位置,offset表示从from_what再移动一定量的距离,比如f.seek(10, 3)表示定位到第三个字符并再后移10个字符。from_what值为0时表示文件的开始,它也可以省略,缺省是0即文件开头。下面给出一

f = open('/tmp/workfile', 'r ') 
f.write('0123456789abcdef') 
f.seek(5) # Go to the 6th byte in the file 
f.read(1)  
'5' 
f.seek (-3, 2) # Go to the 3rd byte before the end 
f.read(1) 
'd' 

五、关闭文件释放资源
文件操作完毕,一定要记得关闭文件f.close(),可以释放资源供其他程序使用
Python读写文件在计算机语言中被广泛的应用,如果你想了解其应用的程序,以下的文章会给你详细的介绍相关内容,会你在以后的学习的过程中有所帮助,下面我们就详细介绍其应用程序。

一、python中对文件、文件夹操作时经常用到的os模块和shutil模块常用方法。

1.得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd()
2.返回指定目录下的所有文件和目录名:os.listdir()
3.函数用来删除一个文件:os.remove()
4.删除多个目录:os.removedirs(r"c:python")
5.检验给出的路径是否是一个文件:os.path.isfile()
6.检验给出的路径是否是一个目录:os.path.isdir()
7.判断是否是绝对路径:os.path.isabs()
8.检验给出的路径是否真地存:os.path.exists()
9.返回一个路径的目录名和文件名:os.path.split()
例子:
代码如下:
os.path.split('/home/swaroop/byte/code/poem.txt') 结果:('/home/swaroop/byte/code', 'poem.txt')

10.分离扩展名:os.path.splitext()
11.获取路径名:os.path.dirname()
12.获取文件名:os.path.basename()
13.运行shell命令: os.system()
14.读取和设置环境变量:os.getenv() 与os.putenv()
15.给出当前平台使用的行终止符:os.linesep Windows使用'rn',Linux使用'n'而Mac使用'r'
16.指示你正在使用的平台:os.name 对于Windows,它是'nt',而对于Linux/Unix用户,它是'posix'
17.重命名:os.rename(old, new)
18.创建多级目录:os.makedirs(r"c:pythontest")
19.创建单个目录:os.mkdir("test")
20.获取文件属性:os.stat(file)
21.修改文件权限与时间戳:os.chmod(file)
22.终止当前进程:os.exit()
23.获取文件大小:os.path.getsize(filename)
二、文件操作方法大全 1.os.mknod("test.txt") 创建空文件
2.fp = open("test.txt",w) 直接打开一个文件,如果文件不存在则创建文件
3.关于open 模式:

复制代码 代码如下:
r:以读方式打开文件,可读取文件信息。
w:以写方式打开文件,可向文件写入信息。如文件存在,则清空该文件,再写入新内容
a:以追加模式打开文件(即一打开文件,文件指针自动移到文件末尾),如果文件不存在则创建
b:以二进制模式打开文件,而不是以文本模式。该模式只对Windows或Dos有效,类Unix的文件是用二进制模式进行操作的。
r :以读写模式打开
w :以读写模式打开 (参见 w )
a :以读写模式打开 (参见 a )
rb:以二进制读模式打开
wb:以二进制写模式打开 (参见 w )
ab:以二进制追加模式打开 (参见 a )
rb :以二进制读写模式打开 (参见 r )
wb :以二进制读写模式打开 (参见 w )
ab :以二进制读写模式打开 (参见 a )

文件对象方法
f.close():关闭文件,记住用open()打开文件后一定要记得关闭它,否则会占用系统的可打开文件句柄数。
f.fileno():获得文件描述符,是一个数字
f.flush():刷新输出缓存
f.isatty():如果文件是一个交互终端,则返回True,否则返回False。
f.read([count]):读出文件,如果有count,则读出count个字节。
f.readline():读出一行信息。
f.readlines():
读出所有行,也就是读出整个文件的信息。
f.seek(offset[,where]):把文件指针移动到相对于where的offset位置。where为0表示文件开始处,这是默认值 ;1表示当前位置;2表示文件结尾。
f.tell():获得文件指针位置。
f.truncate([size]):截取文件,使文件的大小为size。
f.write(string):把string字符串写入文件。
f.writelines(list):把list中的字符串一行一行地写入文件,是连续写入文件,没有换行。

fp.read([size]) #size为读取的长度,以byte为单位
fp.readline([size]) #读一行,如果定义了size,有可能返回的只是一行的一部分
fp.readlines([size]) #把文件每一行作为一个list的一个成员,并返回这个list。其实它的内部是通过循环调用readline()来实现的。如果提供size参数,size是表示读取内容的总长,也就是说可能只读到文件的一部分。
fp.write(str) #把str写到文件中,write()并不会在str后加上一个换行符
fp.writelines(seq) #把seq的内容全部写到文件中(多行一次性写入)。这个函数也只是忠实地写入,不会在每行后面加上任何东西。
fp.close() #关闭文件。python会在一个文件不用后自动关闭文件,不过这一功能没有保证,最好还是养成自己关闭的习惯。 如果一个文件在关闭后还对其进行操作会产生ValueError
fp.flush() #把缓冲区的内容写入硬盘
fp.fileno() #返回一个长整型的"文件标签"
fp.isatty() #文件是否是一个终端设备文件(unix系统中的)
fp.tell() #返回文件操作标记的当前位置,以文件的开头为原点
fp.next() #返回下一行,并将文件操作标记位移到下一行。把一个file用于for … in file这样的语句时,就是调用next()函数来实现遍历的。
fp.seek(offset[,whence]) #将文件打操作标记移到offset的位置。这个offset一般是相对于文件的开头来计算的,一般为正数。但如果提供了whence参数就不一定了,whence可以为0表示从头开始计算,1表示以当前位置为原点计算。2表示以文件末尾为原点进行计算。需要注意,如果文件以a或a 的模式打开,每次进行写操作时,文件操作标记会自动返回到文件末尾。
fp.truncate([size]) #把文件裁成规定的大小,默认的是裁到当前文件操作标记的位置。如果size比文件的大小还要大,依据系统的不同可能是不改变文件,也可能是用0把文件补到相应的大小,也可能是以一些随机的内容加上去。

三、目录操作方法大全

1.创建目录

os.mkdir("file")                  
2.复制文件:
shutil.copyfile("oldfile","newfile")        #oldfile和newfile都只能是文件
shutil.copy("oldfile","newfile")            #oldfile只能是文件夹,newfile可以是文件,也可以是目标目录
3.复制文件夹:
4.shutil.copytree("olddir","newdir")        #olddir和newdir都只能是目录,且newdir必须不存在
5.重命名文件(目录)
os.rename("oldname","newname")              #文件或目录都是使用这条命令
6.移动文件(目录)
shutil.move("oldpos","newpos")  
7.删除文件
os.remove("file")
8.删除目录
os.rmdir("dir")                             #只能删除空目录
shutil.rmtree("dir")                        #空目录、有内容的目录都可以删
9.转换目录
os.chdir("path")                            #换路径

目录操作:
os.mkdir("file")                   创建目录
复制文件:
shutil.copyfile("oldfile","newfile")       oldfile和newfile都只能是文件
shutil.copy("oldfile","newfile")            oldfile只能是文件夹,newfile可以是文件,也可以是目标目录
复制文件夹:
shutil.copytree("olddir","newdir")        olddir和newdir都只能是目录,且newdir必须不存在
重命名文件(目录)
os.rename("oldname","newname")       文件或目录都是使用这条命令
移动文件(目录)
shutil.move("oldpos","newpos")  
删除文件
os.remove("file")
删除目录
os.rmdir("dir")只能删除空目录
shutil.rmtree("dir")    空目录、有内容的目录都可以删
转换目录
os.chdir("path")   换路径

编程实例:   

# -*- coding: utf-8 -*- 

import os 
import shutil 

# 一. 路径操作:判断、获取和删除 

#1. 得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd() 
#print: currentpath: f:LearnPython 
currentpath = os.getcwd() 
print "currentpath: ",currentpath 
#2. 返回指定目录下的所有文件和目录名:os.listdir() 
#print:os.listdir(): ['test.txt', 'testRW.py', 'test1.txt', 'cmd.py', 'rwfile.py', 'downloadfile.py', 'date.py', 'time.py', 'datetime.py', 'file.py'] 
print "os.listdir(): ",os.listdir('f:LearnPython') 

path = "F:mmmmmmmmm[email protected]_android1.6_3.2.1.apk" 
#3. 判断给出的路径是否真地存:os.path.exists() 
if os.path.exists(path): 
  #删除一个文件:os.remove() 
  os.remove(path) 
else: 
  print path,"not exist" 

#4. 删除多个目录:os.removedirs(“c:python”) 
#它只能删除空目录,如果目录里面有内容将不会被删除 
if os.path.exists("d:/woqu"): 
  os.removedirs("d:/woqu") 
else: 
  os.mkdir("d:/woqu") 
  os.removedirs("d:/woqu") 

#5. 判断给出的路径是否是一个文件:os.path.isfile() 
#print: True 
print os.path.isfile("D:hellojson.txt") 
#6. 判断给出的路径是否是一个目录:os.path.isdir() 
#print: True 
print os.path.isdir("D:hello") 
#7. 判断是否是绝对路径:os.path.isabs() 
#print: True 
print os.path.isabs("D:hello") 
# 判断是否是链接 
print os.path.islink('http://www.baidu.com') 
#8. 返回一个路径的目录名和文件名:os.path.split()    
#eg os.path.split('/home/swaroop/byte/code/poem.txt') 结果:('/home/swaroop/byte/code', 'poem.txt')  
#print: ('D:\hello', 'json.txt') 
print os.path.split("D:hellojson.txt") 
#9. 分离扩展名:os.path.splitext() 
#print:('D:\hello\json', '.txt') 
print os.path.splitext("D:hellojson.txt") 
#10. 获取路径名:os.path.dirname() 
#print: 'D:\hello' 
print os.path.dirname("D:hellojson.txt") 
#11. 获取文件名:os.path.basename() 
#print: 'json.txt' 
print os.path.basename("D:hellojson.txt") 


#13. 指示你正在使用的平台:os.name    对于Windows,它是'nt',而对于Linux/Unix用户,它是'posix' 
print "os.name: ",os.name 

#14. linex 下的命令 
if os.name == 'posix': 
  #读取和设置环境变量:os.getenv() 与os.putenv() 
  home_path = os.environ['HOME'] 
  home_path = os.getenv('HOME') #读取环境变量  
elif os.name == 'nt': 
  home_path = 'd:'  
  print 'home_path: ',home_path 

#15. 给出当前平台使用的行终止符:os.linesep  Windows使用'rn',Linux使用'n'而Mac使用'r' 
print(os.linesep) 

#16. 应为windows和linux的路径有点点不一样,windows是用 \ 来分割的,linux是用 / 来分隔, 
#而用os.sep 会自动根据系统选择用哪个分隔符。 
print(os.sep) 

#17. 重命名:os.rename(old, new) 
#先进入目录 
os.chdir("d:\hello") 
print os.getcwd()  
#18. 再重命名 
os.rename("1.txt", "11.txt") 
#19. 创建多级目录:os.makedirs(“c:pythontest”) 
os.makedirs('d:hello') 
#20. 创建单个目录:os.mkdir(“test”) 
os.mkdir('d:f') 
#21. 获取文件属性:os.stat(file) 
#print: nt.stat_result(st_mode=33206, st_ino=0L, st_dev=0, st_nlink=0, st_uid=0, st_gid=0, st_size=497L, st_atime=1346688000L, st_mtime=1346748054L, st_ctime=1346748052L) 
print os.stat('d:hellojson.txt') 
#22. 修改文件权限与时间戳:os.chmod(path,mode) 
#这里有介绍:http://blog.csdn.net/wirelessqa/article/details/7974477 
#23. 终止当前进程:os.exit() 
#24. 获取文件大小:os.path.getsize(filename) 
print os.path.getsize('d:/hello/json.txt') 

python中如何将列表写入文件:
实例:

a = [1,2,3,4,5,6,7,8,9] 
tmp = [] 
for i in range(0,len(a),3): 
 tmp.append(str(a[i]) "," str(a[i 1]) "," str(a[i 2]) "n") 
file("./a.txt",'w').writelines(tmp) 

python 读取txt文件到列表中
实例:
假如txt文件内容为:aaa,bbb,ccc
ddd,eee,fff

我要读取保存到列表中去,显示结果为[[aaa,bbb,ccc],[ddd,eee,fff]]

txtpath=r"a.txt" 
fp=open(txtpath) 
arr=[] 
for lines in fp.readlines(): 
  lines=lines.replace("n","").split(",") 
  arr.append(lines) 
fp.close() 

为了安全起见,最好还是给打开的文件对象指定一个名字,这样在完成操作之后...

文件和文件夹

您可能感兴趣的文章:

  • python读文件逐行处理的示例代码分享
  • python处理文本文件实现生成指定格式文件的方法
  • python处理文本文件并生成指定格式的文件
  • python处理PHP数组文本文件实例
  • Python open()文件处理使用介绍
  • 实例Python处理XML文件的方法

本文给大家介绍Python文件处理相关知识,具体内容如下所示: 1.文件的常见操作 文件是日常编程中常用的操作,通常用于...

目录和文件操作

文件:文本文件、二进制文件

语言只有和外部连起来操作才会实现更强大的功能,比如操作文件、数据库等,这样数据可以有一块单独存储的地方,而不是存放在内存中。更强大的是网络编程,当然这些后续都会学习。接下来学习python对目录和文件的操作。前面的笔记都是基础理论知识,我觉得从这里开始几乎就可以干一些事了。

文件夹:(windows) G:pythonWorkspacepythonstudy   

有关文件夹与文件的查找,删除等功能 在os模块中实现。使用时需先导入这个模块:import  os

    (linux/mac) /home/workspace/python

目录

    注意:文件夹路径的斜杠linux与windows不同

1、取得当前目录——os.getcwd()

windows下文件路径:示例 

>>>importos>>> s=os.getcwd()#获得当前运行脚本所在目录>>>s'C:\Python27'

1 >>> p1="G:pythonWorkspacepythonstudytest.txt"
2 >>> p2 =r"G:pythonWorkspacepythonstudytest.txt"
3 >>> p3 ="G:\pythonWorkspace\python\study\test.txt"

比如运行test.py,那么输入该命令就会返回脚本所在的文件夹位置。

 

例如将test.py放入A文件夹。并且希望不管将A文件夹放在硬盘的哪个位置,都可以在A文件夹内生成一个新文件夹。且文件夹的名字根据时间自动生成。

跨平台路径:os.path.abspath(path)

>>>importos>>>importtime>>> folder = time.strftime(r"%Y-%m-%d_%H-%M-%S",time.localtime())>>>os.makedirs(r'%s/%s'%(os.getcwd(),folder))#创建以时间命名文件夹名

查看属性:os.stat(filename)

这是运行脚本的目录即'C:\Python27'下多了一个以当前时间命名的文件夹

p2 =r"G:pythonWorkspacepythonstudytest.txt"

1 >>> import os #引入os 模块

2 >>> os.stat(p2) #查看文件属性 3 nt.stat_result(st_mode=33206, st_ino=0L, st_dev=0L, st_nlink=0, st_uid=0, st_gid=0, st_size=14L, st_atime=1520953379L, st_mtime=1520953401L, st_ctime=1520953379L) 4 >>>

2、创建子目录——os.makedirs("path"),path是要创建的子目录

 

>>> os.makedirs("C:\temp\test")#这是C盘下就创建了temp目录,temp下嵌套的文件夹是test

读、写文件

(当然,也可能创建失败,比如path已存在,或者驱动器不在,或者无写权限等等)

python 中文件也是一种类型的对象,有属性 __iter__,说明是可迭代的

3、更改当前目录——os.chdir()

打开一个文件

相当于dos或Linux下的cd命令

>>> dir(file)  #查看文件的属性
['__class__', '__delattr__', '__doc__', '__enter__', '__exit__', '__format__', '__getattribute__', '__hash__', '__init__', '__iter__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'close', 'closed', 'encoding', 'errors', 'fileno', 'flush', 'isatty', 'mode', 'name', 'newlines', 'next', 'read', 'readinto', 'readline', 'readlines', 'seek', 'softspace', 'tell', 'truncate', 'write', 'writelines', 'xreadlines']
>>> f =open(p2) #打开一个文件
>>> for line in f:  #循环读取文件内容
...     print line #打印出来后,两行之间有空行,原因print 会自动的带上一个换行符
...
study python

aaaaa

>>> f =open(p2) #第二次也要open文件
>>> for line in f:
...     print line, #出现空行解决方式在line后面加,
...
study python
aaaaa
>>>

>>> os.chdir('c:\')#将当前目录改为C盘根目录下

写文件

4、将路径分解为目录名和文件名——os.path.split()

w 模式 打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件

格式为:fpath , fname = os.path.split( "要分解的路径")

a 模式 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。

>>> a,b=os.path.split("c:\dir1\dir2\file.txt")>>>printa

with 语句 可以不写close() 

c:dir1dir2>>>printb

1 >>> nf =open("G:\pythonWorkspace\python\study\test.txt","w") #打开一个文件,用w模式,写入
2 >>> nf.write("This is a new file.") #将这句话写入文件
3 >>> nf.close() #打开一个文件,写入后必须关闭掉
4 >>> nf =open("G:\pythonWorkspace\python\study\test.txt")
5 >>> for line in nf:
6 ...     print line
7 ...
8 This is a new file.

 1 >>> with open("G:\pythonWorkspace\python\study\test.txt","a") as fp:  #with open 也可以创建文件 打开文件,适用with open write后面的close()可以不写,它会自动处理
 2 ...     fp.write("n what's your name?")
 3 ...
 4 
 5 >>> f =open("G:\pythonWorkspace\python\study\test.txt")
 6 >>> for line in f:
 7 ...     print line
 8 ...
 9 
10 
11  what's your name?
12 >>>

file.txt

不同的读文件方法

5、分解文件名的扩展名——os.path.splitext()

 1 >>> help(file.read)
 2 Help on method_descriptor:
  #参数size可选,如果没有参数,将文件的全部内容读取,如果有参数,将读取到指定的字节,然后将读取到的这些内容以字符串形式返回
 3 所读取的内容一次返回到内存中,随时可以取用,方便快捷。这种方式,如果文件特别大的时候,会使内存开销太大。
 4 read(...)
 5     read([size]) -> read at most size bytes, returned as a string. 
 6 
 7     If the size argument is negative or omitted, read until EOF is reached. 
 8     Notice that when in non-blocking mode, less data than what was requested
 9     may be returned, even if no size parameter was given.
10 
11 >>> help(file.readline)
12 Help on method_descriptor: 
13 参数(size)可选,它是以行为单位返回一个字符串,每次读取一行,依次循环往下读取,如果没有参数,则将读取到文件最后,返回空字符串,到达文件末尾。END OF FILE (EOF)
14 readline(...)
15     readline([size]) -> next line from the file, as a string.
16 
17     Retain newline.  A non-negative size argument limits the maximum
18     number of bytes to return (an incomplete line may be returned then).
19     Return an empty string at EOF.
20 
21 >>> help(file.readlines)
22 Help on method_descriptor:
23 返回以行为单位的列表,相当于执行readline, 得到每一行,然后把这一行的字符串,作为列表中的元素,再放到一个列表中,最后将列表返回。
24 readlines(...)
25     readlines([size]) -> list of strings, each a line from the file.
26 
27     Call readline() repeatedly and return a list of the lines so read.
28     The optional size argument, if given, is an approximate bound on the
29     total number of bytes in the lines returned.

格式为:fpath_name , ftext = os.path.splitext( "要分解的路径")

示例:读取文件

>>> a,b=os.path.splitext("c:\dir1\澳门新萄京官方网站:Python文件处理,学习笔记。dir2\file.txt")>>>printa

  read()      读取文件内容,如果指定参数,将指定字节相应的内容返回,如果没有指定参数,将文件内容全部返回。

c:dir1dir2file>>>printb

  readline() 以行为单位读取文件,返回一个字符串,每次读取一行,一次循环往下读取。如果没有指定参数,将读取到文件末尾。

.txt

  readlines() 返回以行为单位的列表,相当于执行readline,得到每一行,然后把这一行的字符串,作为列表的元素,最后将这个列表返回

6、判断一个路径(目录或文件)是否存在——os.path.exists()

  import fileinput 读取大文件时,使用 

格式为:os.path.exists(“要判断的路径或文件”)

  f.seek(0) 改变当前文件的位置

;)

  f.tell() 告诉文件当前的指针位置,文件内的当前位置

澳门新萄京官方网站 1

 1 >>> f =open("G:\pythonWorkspace\python\study\test.txt")
 2 >>> c=f.read() #把文件的全部内容读取出来,放到一个变量
 3 >>> c
 4 "n what's your name?"
 5 >>> f =open("G:\pythonWorkspace\python\study\test.txt")
 6 >>> f.read(5) #有参数,将返回相应字节的内容
 7 'n wha'
 8 >>> f =open("G:\pythonWorkspace\python\study\test.txt")
 9 >>> f.readline() 返回第一行的内容,每一行都是一个字符串
10 'n'
11 >>> f =open("G:\pythonWorkspace\python\study\test.txt")
12 >>> f.readlines()  返回一个列表,列表中每一行为一个元素
13 ['n', " what's your name?"]
14 >>> import fileinput #引入大文件模块,避免文件太大,内存过满的问题
15 >>> for line in fileinput.input("G:\pythonWorkspace\python\study\bigfile.txt"):
16 ...     print line
17 ...
18 Before getting started,
19 
20 you may want to find out which IDEs and text editors are tailored to make Python editing easy,
21 
22 browse the list of introductory books,
23 
24 or look at code samples that you might find helpful.
25 
26 There is a list of tutorials suitable for experienced programmers on the BeginnersGuide/Tutorials page.
27 
28 There is also a list of resources in other languages which might be useful if English is not your first language.
29 >>> f=open("G:\pythonWorkspace\python\study\bigfile2.txt")
30 >>> for line in f:
31 ...     print line
32 ...
33 Before getting started,
34 
35 you may want to find out which IDEs and text editors are tailored to make Python editing easy,
36 
37 browse the list of introductory books,
38 
39 or look at code samples that you might find helpful.
40 
41 There is a list of tutorials suitable for experienced programmers on the BeginnersGuide/Tutorials page.
42 
43 There is also a list of resources in other languages which might be useful if English is not your first language.
  #每次读取完一个文件之后,都需要重新把这个文件再打开一次,之所以这样做是因为指针已经移到文件最后了。
44 >>> f.seek(0) #使用seek()移动指针,参数0为,指针回到文件最开始,
45 >>> f.readline()
46 'Before getting started, n'
47 >>> f.tell() #使用tell()查看当前指针的位置
48 26L
49 >>> f.seek(4) #参数为4,将指针定位到从开头到第4个字符的位置的后面
50 >>> f.tell()
51 4L
52 >>>

>>> os.path .exists ("C:\")#该路径存在True>>> os.path .exists ("C:\123\")#该路径不存在False>>> os.path .exists ("C:\123.txt")#该文件不存在False>>> os.path .exists ("C:\test.txt")#该文件存在True

 

;)

澳门新萄京官方网站 2

7、判断一个路径是否有需要的文件——os.path.isfile("文件")

>>> os.path .isfile("C:\test.txt")

True>>> os.path .isfile("C:\123.txt")

False

8、判断一个路径是否存在——os.path.isdir("路径")

>>> os.path .isdir("C:\")

True>>> os.path .isdir("H:\")

False

9、获取目录中的文件及子目录的列表——os.listdir("路径")

相当于Windows下powershell中获取Get-ChildItem命令和Linux中的ls命令。但是这个显示不是以常见的列表的形式:

>>> os.listdir("C:\")  #这里包括隐藏文件也显示出来了

['$Recycle.Bin','360ld','360rescue','360SANDBOX','360SysRt','Boot','bootmgr','BOOTSECT.BAK','CacheTemp','Documents and Settings','grldr','IFRToolLog.txt','inetpub','MSOCache','pagefile.sys','Program Files','Program Files (x86)','ProgramData','Python27','Recovery','RECYCLER','SBTDR','System Volume Information','test.txt','Users','Windows']

示例:获取指定目录下的所有子目录的列表

View Code

获取指定目录下所有文件的列表

View Code

10、删除子目录——os.rmdir("path"),只能删除空目录

>>> os.rmdir("C:\temp\test")#注意只删除了test目录>>> os.rmdir("C:\temp")#这里才删除了temp目录

文件

python中模块的引入使得对文件的操作变的很简单。最基本的文件操作就是在文件中进行读写数据,在操作文件之前要打开文件。

打开文件——open('file'[,'mode'])

>>>import os

>>>os.getcwd()'c:\'>>> file=open('test.txt')#默认的mode是'r',即读模式>>>file.read()  #读取文件内容'hellonworldnhello,python'  #  n在文件中的形式是换行

mode的选项即含义如下:

模 式

描述

r

以读方式打开文件,可读取文件信息。

w

以写方式打开文件,可向文件写入信息。如文件存在,则清空该文件,再写入新内容;如果文件不存在则创建

a

澳门新萄京官方网站:Python文件处理,学习笔记。以追加模式打开文件(即一打开文件,文件指针自动移到文件末尾),如果文件不存在则创建

r

以读写方式打开文件,可对文件进行读和写操作。

w

消除文件内容,然后以读写方式打开文件。

a

以读写方式打开文件,并把文件指针移到文件尾。

b

以二进制模式打开文件,而不是以文本模式。该模式只对Windows或Dos有效,类Unix的文件是用二进制模式进行操作的。

关于文件的其他操作我觉得没必要记录的很详细了,因为基本都很简单,下面列出的是文件的常用方法,并且在例子中有相关说明。另外有一点注意的是读取文件中经常存在的编码问题。不同的解释器默认的编码不同,具体解决方案会再介绍。

常见文件操作方法:

方法

描述

f.close()

关闭文件,记住用open()打开文件后一定要记得关闭它,否则会占用系统的可打开文件句柄数。

f.name()

获取文件名称

f.next()

返回下一行,并将文件操作标记位移到下一行。把一个file用于for … in file这样的语句时,就是调用next()函数来实现遍历的。

f.fileno()

获得文件描述符,是一个数字。返回一个长整型的”文件标签“

f.flush()

刷新输出缓存,把缓冲区的内容写入硬盘

f.isatty()

如果文件是一个终端设备文件(Linux系统中),则返回True,否则返回False。

f.read([size])

读出文件,size为读取的长度,以byte为单位

f.readline([size])

读出一行信息,若定义了size,则读出 一行的一部分

f.readlines([size])

读出所有行,也就是读出整个文件的信息。(把文件每一行作为一个list的一个成员,并返回这个list。其实它的内部是通过循环调用readline()来实现的。如果提供size参数,size是表示读取内容的总长,也就是说可能只读到文件的一部分)

f.seek(offset[,where])

把文件指针移动到相对于where的offset位置。where为0表示文件开始处,这是默认值 ;1表示当前位置;2表示文件结尾。(注意:如果文件以a或a 的模式打开,每次进行写操作时,文件操作标记会自动返回到文件末尾)

f.tell()

获得文件指针位置,标记当前位置,以文件开头为原点

f.truncate([size])

把文件裁成规定的大小,默认的是裁到当前文件操作标记的位置。如果size比文件的大小还要大,依据系统的不同可能是不改变文件,也可能是用0把文件补到相应的大小,也可能是以一些随机的内容加上去。

f.write(string)

把string字符串写入文件,write()不会在str后加上一个换行符。

f.writelines(list)

把list中的字符串一行一行地写入文件,是连续写入文件,没有换行。

现有一个test.txt文件,格式如下:

hello

world

hello

python

下面是一些常见操作:

;)

澳门新萄京官方网站 3

>>> file=open('test.txt')>>> file.read (4)#读取前4个字节'hell'>>> file.read(6)#注意这里是在刚才读过的基础上再向后读的'onworl'>>> file.read ()#不指定size,则读到文件结尾'dnhellonpython'>>> file.read()#再读时已是文件结尾''>>> file.seek(0)#将文件位置定位到第一个字节>>> file.readline ()#一次读一行'hellon'>>>file.readline ()'worldn'>>> file.seek(0)#将文件定位到开始>>> file.readlines ()#读取整个文件的内容['hellon','worldn','hellon','python']

>>> file .tell()#读完之后显示seek位置,即文件的最后了

27L#以长整型表示

>>> file.name#查看文件的名称

'test.txt'

>>> file.close()#关闭文件

;)

澳门新萄京官方网站 4

刚开始测试read和readline等用法的时候,因为只要读取一次就在上次基础上往后读,当时我还以为这是一个出栈操作,显然,知道有seek这个方法后,我才知道它不是,只是每次读的时候seek的位置就往后移动一个,而每次读取是以seek所在的位置为起点的。所以如果需要从头开始读取文件内容时,将文件位置设为开始即可,即seek(0)。

>>> file=open('test.txt','w')>>> file.write ('nwelcome')#会将之前的内容覆盖>>> file.writelines ('I love python')>>> file.close ()#关闭文件时才能看到文件内容的修改

>>> file=open('test.txt','a')#追加到文件尾,而不会覆盖>>> file.writelines ('this is a test')>>> file.close()

对文件的相关操作有时需要引入shutil模块:

;)

澳门新萄京官方网站 5

>>>importshutil>>> shutil.copyfile('test.txt','123.txt')#参数只能是文件>>> shutil.copy("olddir","newfileordir")#olddir只能是文件夹,newfile可以是文件,也可以是目标目录>>> shutil.copytree("olddir","newdir")#olddir和newdir都只能是目录,且newdir必须不存在>>> shutil.move("oldpos","newpos")#移动文件或目录>>> shutil.rmtree("dir")#空目录、有内容的目录都可以删>>>importos

>>>os.rmdir("dir")#只能删除空目录>>> os.remove("file")#删除文件>>> os.rename("oldname","newname")#文件或目录都是使用这条命令

;)

澳门新萄京官方网站 6

关于文件和目录操作的总结,推荐博客:http://www.cnblogs.com/rollenholt/archive/2012/04/23/2466179.html

文件编码:

;)

澳门新萄京官方网站 7

#获得当前环境默认编码>>>importsys>>>importlocale>>>sys.getdefaultencoding()# 返回当前系统所使用的默认字符编码'ascii'>>>sys.getfilesystemencoding ()# 返回用于转换Unicode文件名至系统文件名所使用的编码'mbcs'>>>locale.getdefaultlocale()# 获取默认的区域设置并返回元组(语言, 编码)('zh_CN','cp936')>>>locale .getpreferredencoding ()# 返回用户设定的文本数据编码'cp936'

;)

澳门新萄京官方网站 8

本文由澳门新萄京官方网站发布于www.8455.com,转载请注明出处:澳门新萄京官方网站:Python文件处理,学习笔记

关键词: