美文网首页
文件操作 Python

文件操作 Python

作者: IT小白1002 | 来源:发表于2017-04-25 08:35 被阅读0次

    基于字符读写

    最基本的文件操作当然就是在文件中读写数据。这也是很容易掌握的。现在打开一个文件以进行写操作:

    1. fileHandle = open ( 'test.txt', 'w' )

    ‘w'是指文件将被写入数据,语句的其它部分很好理解。下一步就是将数据写入文件:

    2. fileHandle.write ( 'This is a test.\nReally, it is.' )

    这个语句将“This is a test.”写入文件的第一行,“Really, it is.”写入文件的第二行。最后,我们需要做清理工作,并且关闭文件:

    3. fileHandle.close()

    正如你所见,在Python的面向对象机制下,这确实非常简单。需要注意的是,当你再次使用“w”方式在文件中写数据,所有原来的内容都会被删除。如果想保留原来的内容,可以使用“a”方式在文件中结尾附加数据

    1. fileHandle = open ( 'test.txt', 'a' )

    2. fileHandle.write ( '\n\nBottom line.' )

    3. fileHandle.close()

    以上语句将读取整个文件并显示其中的数据

    基于行的读写

    1. fileHandle = open ( 'test.txt' )

    2. print fileHandle.readline()

    3. fileHandle.close()

    同时,也可以将文件内容保存到一个list中:

    1. fileHandle = open ( 'test.txt' )

    2. fileList = fileHandle.readlines()

    3. for fileLine in fileList:

    4.     print '>>', fileLine

    5. fileHandle.close()

    或者在文件中一次读取几个字节的内容:

    1. fileHandle = open ( 'test.txt' )

    2. print fileHandle.read ( 1 )

    3. fileHandle.seek ( 4 ) #随机访问文件中的位置 seek

    4. print FileHandle.read ( 1 )


    需要以二进制方式读写文件,比如图片和可执行文件。此时,只要在打开文件的方式参数中增加一个“b”即可:


    Python中的二进制

    python没有二进制类型,但可以存储二进制类型的数据,就是用string字符串类型来存储二进制数据,这也没关系,因为string是以1个字节为单位的。

    import struct

    a=12.34

    #将a变为二进制

    bytes=struct.pack('i',a)

    此时bytes就是一个string字符串,字符串按字节同a的二进制存储内容相同。


    再进行反操作

    现有二进制数据bytes,(其实就是字符串),将它反过来转换成python的数据类型:

    a,=struct.unpack('i',bytes)#注意是"a,"而不是“a”

    注意,unpack返回的是tuple


    python中对文件、文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块。

    得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd()

    返回指定目录下的所有文件和目录名:os.listdir()

    函数用来删除一个文件:os.remove()

    删除多个目录:os.removedirs(r“c:\python”)

    检验给出的路径是否是一个文件:os.path.isfile()

    检验给出的路径是否是一个目录:os.path.isdir()

    判断是否是绝对路径:os.path.isabs()

    检查是否快捷方式os.path.islink ( filename )

    检验给出的路径是否真地存:os.path.exists()

    返回一个路径的目录名和文件名:os.path.split() eg os.path.split('/home/swaroop/byte/code/poem.txt') 结果:('/home/swaroop/byte/code', 'poem.txt')

    分离扩展名:os.path.splitext()

    获取路径名:os.path.dirname()

    获取文件名:os.path.basename()

    运行shell命令: os.system()

    读取和设置环境变量:os.getenv() 与os.putenv()

    给出当前平台使用的行终止符:os.linesep Windows使用'\r\n',Linux使用'\n'而Mac使用'\r'

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

    重命名:os.rename(old, new)

    创建多级目录:os.makedirs(r“c:\python\test”)

    创建单个目录:os.mkdir(“test”)

    获取文件属性:os.stat(file)

    修改文件权限与时间戳:os.chmod(file)

    终止当前进程:os.exit()

    获取文件大小:os.path.getsize(filename)

    文件操作:

    os.mknod("test.txt")        创建空文件

    fp = open("test.txt",w)    直接打开一个文件,如果文件不存在则创建文件

    关于open 模式:

    w    以写方式打开,

    a    以追加模式打开 (从 EOF 开始, 必要时创建新文件)

    r+    以读写模式打开

    w+    以读写模式打开 (参见 w )

    a+    以读写模式打开 (参见 a )

    rb    以二进制读模式打开

    wb    以二进制写模式打开 (参见 w )

    ab    以二进制追加模式打开 (参见 a )

    rb+    以二进制读写模式打开 (参见 r+ )

    wb+    以二进制读写模式打开 (参见 w+ )

    ab+    以二进制读写模式打开 (参见 a+ )

    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把文件补

    到相应的大小,也可能是以一些随机的内容加上去。

    目录操作:

    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")  换路径

    相关文章

      网友评论

          本文标题:文件操作 Python

          本文链接:https://www.haomeiwen.com/subject/etimzttx.html