Python_05-文件操作

目录:

1             文件操作

1.1          快速入门

1.1.1       用Python创建一个新文件

1.1.2       文件内容追加,从0到9的10个随机整数

1.1.3       文件内容追加,从0到9的随机整数, 10个数字一行,共10行

1.1.4       把标准输出定向到文件

1.2          文件的读写

1.2.1       文件打开

1.2.2       关闭文件

1.2.3       清空文件内容

1.2.4       文件的指针定位与查询

1.2.5       从文件读取指内容

1.2.6       向文件写入一个字符串

1.2.7       删除文件

1.3          打开文件

1.4          操作函数目录

1.4.1       对文件、文件夹的操作

1.4.2       文件操作

1.4.3       目录操作

1.5          练习

 

 

1       文件操作

1.1   快速入门

1.1.1   用Python创建一个新文件

内容是从0到9的整数, 每个数字占一行:

#python

f=open(‘f.txt‘,‘w‘)    # r只读,w可写,a追加

for i in range(0,10):f.write(str(i)+‘\n‘)

f.close()

 

f=open(‘f.txt‘,‘r‘)    # r只读,w可写,a追加

t=f.readlines()

print(t)

f.close()

1.1.2   文件内容追加,从0到9的10个随机整数

#python

import random

f=open(‘f.txt‘,‘a‘)

for i in range(0,10):f.write(str(random.randint(0,9)))

f.write(‘\n‘)

f.close()

1.1.3   文件内容追加,从0到9的随机整数, 10个数字一行,共10行

#python

import random

f=open(‘f.txt‘,‘a‘)

for i in range(0,10):

     for i in range(0,10):f.write(str(random.randint(0,9)))

     f.write(‘\n‘)   

f.close()

 

如何读取并显示:

#python

g=open(‘f.txt‘,‘rt‘)    # r只读,w可写,a追加

s=g.readlines()

print(s)

for i in range(len(s)):

    s[i]=s[i].strip(‘\n‘)

print(s)

g.close()

1.1.4   把标准输出定向到文件

#python

import sys

sys.stdout = open("stdout.txt", "w")

1.2   文件的读写

1.2.1   文件打开

f = file(name[, mode[, buffering]])

入口参数:   name 文件名

                  mode   选项,字符串

                  buffering   是否缓冲 (0=不缓冲,1=缓冲, >1的int数=缓冲区大小)

返回值 : 文件对象

mode 选项:

"r"   以读方式打开,只能读文件 如果文件不存在,会发生异常     

"w" 以写方式打开,只能写文件, 如果文件不存在,创建该文件

                                                     如果文件已存在,先清空,再打开文件

"rb"   以二进制读方式打开,只能读文件 如果文件不存在,会发生异常     

"wb" 以二进制写方式打开,只能写文件, 如果文件不存在,创建该文件

                                                     如果文件已存在,先清空,再打开文件

"rt"   以文本读方式打开,只能读文件 如果文件不存在,会发生异常     

"wt" 以文本写方式打开,只能写文件, 如果文件不存在,创建该文件

                                                     如果文件已存在,先清空,再打开文件

"rb+"   以二进制读方式打开,可以读、写文件 如果文件不存在,会发生异常     

"wb+" 以二进制写方式打开,可以读、写文件, 如果文件不存在,创建该文件

                                                     如果文件已存在,先清空,再打开文件

1.2.2   关闭文件

f.close()

当文件读写完毕后,应关闭文件。

1.2.3   清空文件内容

f.truncate()

注意:仅当以 "r+"   "rb+"    "w"   "wb" "wb+"等以可写模式打开的文件才可以执行该功能。

1.2.4   文件的指针定位与查询

(1)文件指针:

      文件被打开后,其对象保存在 f 中, 它会记住文件的当前位置,以便于执行读、写操作,这个位置称为文件的指针( 一个从文件头部开始计算的字节数 long 类型 )

(2)文件打开时的位置:

      以"r"   "r+"   "rb+" 读方式, "w"   "w+"   "wb+"写方式 打开的文件,

     一开始,文件指针均指向文件的头部。

(3) 获取文件指针的值:

      L = f.tell()

(4) 移动文件的指针

       f.seek(   偏移量, 选项 )

      选项 =0 时, 表示将文件指针指向从文件头部到 "偏移量"字节处。

      选项 =1 时, 表示将文件指针指向从文件的当前位置,向后移动 "偏移量"字节。

      选项 =2 时, 表示将文件指针指向从文件的尾部,,向前移动 "偏移量"字节。

1.2.5   从文件读取指内容

1 文本文件(以"rt"方式打开的文件)的读取 

          s = f.readline(     )

        返回值: s 是字符串,从文件中读取的一行,含行结束符。

        说明: (1)  如果 len( s ) =0 表示已到文件尾

                    (2)   如果是文件的最后一行,有可能没有行结束符

2 二进制文件(以"rb"、"rb+"、"wb+" 方式打开的文件)的读取 

          s = f.read(    n )

     说明: (1)  如果 len( s ) =0 表示已到文件尾

                  (2)   文件读取后,文件的指针向后移动 len(s) 字节。

                (3)如果磁道已坏,会发生异常。

1.2.6   向文件写入一个字符串

    f.write( s )

    参数:       s 要写入的字符串

    说明: (1)文件写入后,文件的指针向后移动 len(s) 字节。

                 (2)如果磁道已坏,或磁盘已满会发生异常。

返回值: s 是字符串,从文件中读取的内容

1.2.7   删除文件

import os

os.remove(file)

1.3   打开文件

读写文件之前,先用open()函数打开一个文件,它会返回一个文件对象(file object)

f =open(filename,mode)

如果不指定mode参数,文件将默认以‘r‘模式打开。模式中的字符有:

r:只读

w:只写,如果文件已存在则将其覆盖。如果该文件不存在,创建新文件

+:读写(不能单独使用)

a:打开文件用于追加,只写,不存在则创建新文件

b:以二进制模式打开(不能单独使用)

所以可能的模式大概有rwr+w+rbwbrb+wb+aa+abab+,注意只有wa可以创建文件。

 

通常情况下,文件都是以文本模式(text mode)打开的,也就是说,从文件中读写的是以一种特定的编码格式进行编码(默认的是 UTF-8)的字符串。如果文件以二进制模式(binary mode)打开,数据将以字节对象的形式进行读写:

f =open(‘a.txt‘,‘wb+‘)

f.write(‘I like apple!‘)  # 报错

f.write(b‘I like apple!‘) # 以bytes对象的形式进行读写

Bytes对象是0127的不可修改的整数序列,或纯粹的 ASCII 字符,它的用途是存储二进制数据。

可以通过在一个字符串前面加上‘b‘来创建一个bytes literal

也可以通过bytes() 函数创建一个 bytes 对象。

注意:如果bytes() 函数的初始化器是一个字符串,那么必须提供一种编码。

 

b1 =b‘This is string‘

b2 =bytes(‘This is string‘, ‘UTF-8‘)  # 必须指定编码格式

字符串对象与字节对象是不兼容的,要将 bytes 转变为 str, bytes 对象必须要进行解码,使用decode() 方法:

 

b = bytes(‘This is string‘, ‘UTF-8‘)

print(b, b.decode(), sep=‘\n‘)

# 输出:

# b‘This is string‘

# This is string

文件对象的方法(假设f是一个文件对象)

f.read(size) :读取size个字节的数据,然后作为字符串或 bytes 对象返回。size是一个可选参数,如果不指定size,则读取文件的所有内容。
f.readline()
:读取一行。在字符串末尾会留下换行符 (\n),如果到文件尾,返回空字符串。
f.readlines()
:读取所有行,储存在列表中,每个元素是一行,相当于list(f)
f.write(string)
:将 string 写入到文件中,返回写入的字符数。如果以二进制模式写文件,需要将string转换为 bytes 对象。
f.tell()
:返回文件对象当前所处的位置,它是从文件开头开始算起的字节数。
f.seek(offset, from_what)
:改变文件对象所处的位置。offset是相对参考位置的偏移量,from_what 取值 0(文件头, 默认)、1(当前位置)、2(文件尾)表示参考位置。
f.close()
:关闭文件对象。

这些都是很常用的方法,当然文件对象不止这些方法。根据打开的模式不同,open() 返回的文件对象类型也不同:

TextIOWrapper:文本模式,返回TextIOWrapper对象。
BufferedReader
:读二进制,即rb,返回BufferedReader对象。
BufferedWriter
:写和追加二进制,即wbab,返回BufferedWriter对象。
BufferedRandom
:读/写模式,即含有+的模式,返回BufferedRandom对象。
可以在这些文件对象上运行 dir() help(),查看它们所有的方法。

 

1.4  
操作函数目录

1.4.1  
对文件、文件夹的操作

需要涉及到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.exists()

返回一个路径的目录名和文件名:

os.path.split()    

例如:

os.path.split(‘/home/swaroop/byte/code/poem.txt‘)

结果:

(‘/home/swaroop/byte/code‘,
‘poem.txt‘)

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

>>>
t=os.path.splitext("d:\d.txt")

>>>
t[0]

‘d:\\d‘

>>>
t[1]

‘.txt‘

 

获取路径名: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)

1.4.2  
文件操作

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把文件补到相应的大小,也可能是以一些随机的内容加上去。

1.4.3  
目录操作

import
shutil

shutil
-- High-level file operations
是一种高层次的文件操作工具

类似于高级API,而且主要强大之处在于其对文件的复制与删除操作。

 

创建目录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")   换路径

http://www.jb51.net/article/57726.htm

这篇文章主要介绍了Python实现读取目录所有文件的文件名并保存到txt文件代码,本文分别使用os.listdir和os.walk实现给出两段实现代码

代码: (使用os.listdir)

 

import
os 

 def ListFilesToTxt(dir,file,wildcard,recursion):

    exts = wildcard.split(" ")

    files = os.listdir(dir)

    for name in files:

        fullname=os.path.join(dir,name)

        if(os.path.isdir(fullname) &
recursion):

           
ListFilesToTxt(fullname,file,wildcard,recursion)

        else:

            for ext in exts:

                if(name.endswith(ext)):

                    file.write(name +
"\n")

                    break

 def Test():

  dir="J:\\1"

  outfile="binaries.txt"

  wildcard = ".txt .exe .dll .lib"

  file = open(outfile,"w")

  if not file:

    print ("cannot open the file %s for
writing" % outfile)

   ListFilesToTxt(dir,file,wildcard, 1)

 

  file.close()

 Test()

 

代码:(使用os.walk) walk递归地对目录及子目录处理,每次返回的三项分别为:当前递归的目录,当前递归的目录下的所有子目录,当前递归的目录下的所有文件。

 

import
os 

 def
ListFilesToTxt(dir,file,wildcard,recursion):

    exts = wildcard.split(" ")

    for root, subdirs, files in os.walk(dir):

        for name in files:

            for ext in exts:

                if(name.endswith(ext)):

                    file.write(name +
"\n")

                    break

        if(not recursion):

            break

 def Test():

  dir="J:\\1"

  outfile="binaries.txt"

  wildcard = ".txt .exe .dll .lib"

 

  file = open(outfile,"w")

  if not file:

    print ("cannot open the file %s for
writing" % outfile)

   ListFilesToTxt(dir,file,wildcard, 0)

  file.close()

 Test()

 

STARTNOTRANSFORM

相关例子

 1 将文件夹下所有图片名称加上‘_fc‘

python代码:

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

import
re

import
os

import
time

#str.split(string)分割字符串

#‘连接符‘.join(list) 将列表组成字符串

def
change_name(path):

    global i

    if not os.path.isdir(path) and not
os.path.isfile(path):

        return False

    if os.path.isfile(path):

        file_path = os.path.split(path) #分割出目录与文件

        lists = file_path[1].split(‘.‘) #分割出文件与文件扩展名

        file_ext = lists[-1] #取出后缀名(列表切片操作)

        img_ext =
[‘bmp‘,‘jpeg‘,‘gif‘,‘psd‘,‘png‘,‘jpg‘]

        if file_ext in img_ext:

           
os.rename(path,file_path[0]+‘/‘+lists[0]+‘_fc.‘+file_ext)

            i+=1 #注意这里的i是一个陷阱

        #或者

        #img_ext = ‘bmp|jpeg|gif|psd|png|jpg‘

        #if file_ext in img_ext:

        #   
print(‘ok---‘+file_ext)

    elif os.path.isdir(path):

        for x in os.listdir(path):

            change_name(os.path.join(path,x))
#os.path.join()
在路径处理上很有用

 

img_dir
= ‘D:\\xx\\xx\\images‘

img_dir
= img_dir.replace(‘\\‘,‘/‘)

start
= time.time()

i =
0

change_name(img_dir)

c =
time.time() - start

print(‘程序运行耗时:%0.2f‘%(c))

print(‘总共处理了 %s 张图片‘%(i))

输出结果:

程序运行耗时:0.11

总共处理了 109 张图片

 

时间: 2024-10-09 15:18:07

Python_05-文件操作的相关文章

Python 文件操作

操作文件时,一般需要经历如下步骤: 打开文件 操作文件 一.打开文件 文件句柄 = open('文件路径', '模式') 打开文件时,需要指定文件路径和以何等方式打开文件,打开后,即可获取该文件句柄,日后通过此文件句柄对该文件操作. 打开文件的模式有: r,只读模式(默认). w,只写模式.[不可读:不存在则创建:存在则删除内容:] a,追加模式.[可读: 不存在则创建:存在则只追加内容:] "+" 表示可以同时读写某个文件 r+,可读写文件.[可读:可写:可追加] w+,写读 a+,

python基础:python循环、三元运算、字典、文件操作

目录: python循环 三元运算 字符串 字典 文件操作基础 一.python编程 在面向过程式编程语言的执行流程中包含: 顺序执行 选择执行 循环执行 if是条件判断语句:if的执行流程属于选择执行:if语句有三种格式,如下: 在多分支的if表达式中,即使多个条件同时为真,也只会执行一个,首先测试为真: 选择执行 单分支的if语句 if CONDITION: 条件为真分支 双分支的if语句 if CONDITION 条件为真分支 else 条件不满足时分支 多分支的if语句 if CONDI

python文件操作

文件操作:os.mknod("test.txt")        创建空文件fp = open("test.txt",w)     直接打开一个文件,如果文件不存在则创建文件 关于open 模式: w     以写方式打开,a     以追加模式打开 (从 EOF 开始, 必要时创建新文件)r+     以读写模式打开w+     以读写模式打开 (参见 w )a+     以读写模式打开 (参见 a )rb     以二进制读模式打开wb     以二进制写模式打

Python基础(六) 基础文件操作

今天学习python下对文件的基础操作,主要从open函数.File对象的属性.文件定位.简单操作.举例说明几个步骤开始学习,下面开始进入今天的主题: 一.open函数介绍 open函数主要是打开一个文件,创建一个file对象,相关的方法可以调用它进行读写 . 语法格式如下: 1 2 3 file object = open(文件名,打开文件的模式) file object  = with open (文件名,打开文件的模式) as 变量名 两种语法格式的不同在于下面这种方法不用输入f.clos

小何讲Linux: 基本文件操作和实例

文件操作的基本概念参见博客: 小何讲Linux: 底层文件I/O操作 1.  函数说明 open()函数:是用于打开或创建文件,在打开或创建文件时可以指定文件的属性及用户的权限等各种参数. 所谓打开文件实质上是在进程与文件之间建立起一种连接,而"文件描述符"唯一地标识着这样一个连接 close()函数:是用于关闭一个被打开的文件.当一个进程终止时,所有被它打开的文件都由内核自动关闭,很多程序都使用这一功能而不显示地关闭一个文件. read()函数:是用于将从指定的文件描述符中读出的数据

C语言中的文件操作---重定向操作文件

先说个题外话,文件操作以及字符串与字符深入处理(就是那些什么puts(), getchar()什么的)是本人深入认识C++最后的两座大山.而今天先把重定向文件操作解决掉. 输入输出重定向恐怕是文件I/O操作中最简单的方法了,具体用法是现在main函数的开头加入两条语句,例如: freopen("D:\\input.txt", "r", stdin); freopen("D:\\output.txt", "w", stdout)

文件操作

1.C文件操作 2.c++文件操作 3.MFC文件操作:CFile是MFC的文件操作基本类,它直接支持无缓冲的二进制磁盘I/O操作,并通过其派生类支持文本文件.内存文件和socket文件. Visual C++处理的文件通常分为两种: 文本文件:只可被任意文本编辑器读取ASCII文本. 二进制文件:指对包含任意格式或无格式数据的文件的统称. 1.定义文件变量 定义文件变量格式:CStdioFile 文件变量: 例如,定义一个名称为f1的文件变量,语句如下:CStdioFile f1; 2.打开指

Windows DIB文件操作详解-4.使用DIB Section

前面讲了为了提高DIB的显示性能和效率,我们将DIB转换成DDB,但是这又遇到一个问题,如果我想操作DIB的数据的话,显然是不能使用DDB:一是因为DIB转DDB时发生了颜色转换,再就是DDB无法直接提取指定像素点的数据.那么我们怎么办呢,Windows使用一种折中的方式来达到这一目标(既提高了显示效率和性能,又可以直接操作像素点). 1.DIB Section存储和显示 Windows使用DIB块(DIB Section)来存储DIB数据,其内存结构示意图如下 其实,和我们自己读入DIB数据到

C/C++文件操作

1 基于C的文件操作 在ANSI C中,对文件的操作分为两种方式,即流式文件操作和I/O文件操作 2 一.流式文件操作 3 4 1.fopen() 5 FILE *fopen(const char *filename,const char *mode) 6 "r" 以只读方式打开文件 7 "w" 以只写方式打开文件 8 "a" 以追加方式打开文件 9 "r+" 以读/写方式打开文件,如无文件出错 10 "w+&quo

Python学习笔记八:文件操作(续),文件编码与解码,函数,递归,函数式编程介绍,高阶函数

文件操作(续) 获得文件句柄位置,f.tell(),从0开始,按字符数计数 f.read(5),读取5个字符 返回文件句柄到某位置,f.seek(0) 文件在编辑过程中改变编码,f.detech() 获取文件编码,f.encoding() 获取文件在内存中的编号,f.fileno() 获取文件终端类型(tty.打印机等),f.isatty() 获取文件名,f.name() 判断文件句柄是否可移动(tty等不可移动),f.seekable() 判断文件是否可读,f.readable() 判断文件是