Maison > développement back-end > Tutoriel Python > Quelles sont les étapes unifiées utilisées par Python pour les opérations sur les fichiers ?

Quelles sont les étapes unifiées utilisées par Python pour les opérations sur les fichiers ?

青灯夜游
Libérer: 2022-12-30 11:13:48
original
6346 Les gens l'ont consulté

Les étapes unifiées adoptées par Python pour les opérations sur les fichiers sont : "Ouvrir-Opération-Fermer". "Ouvrir-Opération-Fermer" est une étape unifiée dans laquelle "Fermer" peut être omis. Python peut utiliser les méthodes du module os et du module Shutil pour gérer les fichiers et les dossiers.

Quelles sont les étapes unifiées utilisées par Python pour les opérations sur les fichiers ?

L'environnement d'exploitation de ce tutoriel : système Windows 7, version Python 3, ordinateur Dell G3.

Les étapes unifiées utilisées par Python pour les opérations sur les fichiers sont :

A. Opération—Lecture—Ecriture

B. Ouvrir—Lecture—Ecriture— Fermer

C. Ouvrir-lire-écrire-écrire

D Ouvrir-opérer-fermer

Bonne réponse D

Opérations sur les fichiers et dossiers Python

1. Fréquemment utilisé lors de l'exploitation de fichiers et de dossiers en Python Méthodes courantes du système d'exploitation. module et module de fermeture.

1. Obtenez le répertoire de travail actuel, c'est-à-dire le chemin du répertoire dans lequel le script Python actuel fonctionne : os.getcwd()
2. répertoire : os.listdir( )
3. La fonction est utilisée pour supprimer un fichier : os.remove()
4 Supprimer plusieurs répertoires : os.removedirs(r"c:python")
5. . Vérifiez si le chemin donné est un fichier : os.path.isfile()
6. Vérifiez si le chemin donné est un répertoire : os.path.isdir()
7. chemin absolu : os.path.isabs()
8. Vérifiez si le chemin donné existe réellement : os.path.exists()
9. Renvoie le nom du répertoire et le nom de fichier d'un chemin : os.path. split()

Exemple :

os.path.split('/home/swaroop/byte/code/poem.txt')
Copier après la connexion

Résultat :

('/home/swaroop/byte/code',
'poem.txt')
Copier après la connexion

10. Extension divisée : os.path.splitext()
11. : os.path.dirname()
12. Obtenez le nom du fichier : os.path.basename()
13. Exécutez la commande shell : os.system()
14. : os.getenv() et os.putenv()
15. Donne le terminateur de ligne utilisé par la plateforme actuelle : os.linesep Windows utilise 'rn', Linux utilise 'n' et Mac utilise 'r'
. 16. Indiquez la plateforme que vous utilisez : os.name est 'nt' pour Windows et 'posix' pour les utilisateurs Linux/Unix
17. Renommez : os.rename(old, new)
18. Créez plusieurs répertoires de niveau : os.makedirs(r"c:pythontest")
19. Créez un seul répertoire : os.mkdir("test")
20. Obtenez les attributs du fichier : os.stat(file)
. 21. Modifiez les autorisations et les horodatages du fichier : os.chmod(file)
22. Terminez le processus en cours : os.exit()
23. Obtenez la taille du fichier : os.path.getsize(filename)<🎜. >

2. Méthodes complètes de fonctionnement des fichiers

1.os.mknod("test.txt") Créer un fichier vide

2.fp = open("test. txt",w) Ouvrir directement un fichier, si le fichier n'existe pas, créer le fichier
3. A propos du mode ouverture :

  • w : ouvrir en mode écriture,

    a : ouvrir en mode ajout (à partir de EOF Start, créer un nouveau fichier si nécessaire)
    r+ : ouvrir en mode lecture-écriture
    w+ : ouvrir en mode lecture-écriture (voir w)
    a+ : Ouvert en mode lecture-écriture (voir a)
    rb : Ouvert en mode lecture binaire
    wb : Ouvert en mode écriture binaire (voir w)
    ab : Ouvert en mode ajout binaire (voir a)
    rb+ : Ouvert en mode lecture et écriture binaire (voir r+)
    wb+ : Ouvert en mode lecture-écriture binaire (voir w+)
    ab+ : Ouvert en mode lecture-écriture binaire (voir 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.创建目录

os.mkdir("file")
Copier après la connexion

2.复制文件:

shutil.copyfile("oldfile","newfile") #oldfile和newfile都只能是文件
shutil.copy("oldfile","newfile") #oldfile只能是文件夹,newfile可以是文件,也可以是目标目录
Copier après la connexion

3.复制文件夹:

shutil.copytree("olddir","newdir") #olddir和newdir都只能是目录,且newdir必须不存在
Copier après la connexion

5.重命名文件(目录)

os.rename("oldname","newname") #文件或目录都是使用这条命令
Copier après la connexion

6.移动文件(目录)

shutil.move("oldpos","newpos")
Copier après la connexion

7.删除文件

os.remove("file")
Copier après la connexion

8.删除目录

os.rmdir("dir") #只能删除空目录
shutil.rmtree("dir") #空目录、有内容的目录都可以删
Copier après la connexion

9.转换目录

os.chdir("path") #换路径
Copier après la connexion

四、文件综合操作实例

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

python代码:

# -*- coding:utf-8 -*-
import re
import os
import time
#str.split(string)分割字符串
#&#39;连接符&#39;.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(&#39;.&#39;) #分割出文件与文件扩展名
file_ext = lists[-1] #取出后缀名(列表切片操作)
img_ext = [&#39;bmp&#39;,&#39;jpeg&#39;,&#39;gif&#39;,&#39;psd&#39;,&#39;png&#39;,&#39;jpg&#39;]
if file_ext in img_ext:
os.rename(path,file_path[0]+&#39;/&#39;+lists[0]+&#39;_fc.&#39;+file_ext)
i+=1 #注意这里的i是一个陷阱
#或者
#img_ext = &#39;bmp|jpeg|gif|psd|png|jpg&#39;
#if file_ext in img_ext:
# print(&#39;ok---&#39;+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 = &#39;D:\\xx\\xx\\images&#39;
img_dir = img_dir.replace(&#39;\\&#39;,&#39;/&#39;)
start = time.time()
i = 0
change_name(img_dir)
c = time.time() - start
print(&#39;程序运行耗时:%0.2f&#39;%(c))
print(&#39;总共处理了 %s 张图片&#39;%(i))
Copier après la connexion

输出结果:

程序运行耗时:0.11
总共处理了 109 张图片
Copier après la connexion

更多计算机编程相关知识,请访问:编程视频!!

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal