Maison  >  Article  >  développement back-end  >  Comment résoudre l’erreur de lecture de fichier non standard dans le code Python ?

Comment résoudre l’erreur de lecture de fichier non standard dans le code Python ?

WBOY
WBOYoriginal
2023-06-24 13:19:231284parcourir

En Python, la lecture de fichiers est une opération très courante. Cependant, en raison d'irrégularités ou de négligences de la part du rédacteur du code, des erreurs dans la manière dont le fichier est lu peuvent en résulter. Ces erreurs peuvent provoquer des plantages du programme, une perte de temps et même créer des risques de sécurité. Cet article explique comment résoudre les erreurs courantes de lecture de fichiers non standard dans le code Python.

  1. Utiliser des chemins absolus

En Python, les chemins de fichiers sont souvent utilisés pour localiser des fichiers lors de la lecture de fichiers. Cependant, l'utilisation de chemins relatifs peut entraîner des erreurs de lecture de fichiers car les chemins de fichiers sont calculés par rapport au répertoire de travail actuel. La solution à ce problème consiste à utiliser des chemins absolus. Vous pouvez utiliser la fonction os.path.abspath() pour obtenir le chemin absolu du fichier, comme indiqué ci-dessous :

import os
path = os.path.abspath('file.txt')

Ici, 'file.txt' représente le nom du fichier. Cette fonction peut garantir que le fichier peut toujours être localisé correctement et qu'aucune erreur de lecture ne se produira en raison de modifications du chemin du fichier.

  1. Vérifier si le fichier existe

Avant de lire le fichier, il est préférable de vérifier si le fichier existe pour éviter de lire le fichier s'il n'existe pas Provoque des erreurs de programme. Vous pouvez utiliser la fonction os.path.exists() pour vérifier si le fichier existe, comme indiqué ci-dessous :

import os
path = 'file.txt'
if os.path.exists(path):
    with open(path, 'r') as f:
        # 读取文件内容
else:
    print('File does not exist!')

Ici, le chemin est le chemin du fichier. Si le fichier existe, ouvrez-le en lecture ; sinon, imprimez un message d'erreur.

  1. Utilisez l'instruction with

Lorsque vous utilisez Python pour lire un fichier, utilisez l'instruction with pour vous assurer que le fichier est correctement fermé après utilisation et éviter les fuites de ressources. Dans l'instruction with, vous pouvez effectuer une série d'opérations sur les fichiers telles que la lecture et l'écriture, comme indiqué ci-dessous :

path = 'file.txt'
with open(path, 'r') as f:
    # 读取文件内容

Ici, "file.txt" est le nom du fichier et "r" signifie lire. mode uniquement Ouvrez le fichier. A la fin de l'instruction with, le fichier est automatiquement fermé sans fermeture manuelle.

  1. Utiliser le bloc try-sauf

Pendant le processus de lecture du fichier, le fichier peut rencontrer des problèmes de manière inattendue, tels que le fichier est occupé , Le fichier n'existe pas, etc. Utilisez un bloc try-sauf pour éviter ces problèmes et provoquer le crash du programme. Voici un exemple de bloc try-sauf qui lit un fichier :

path = 'file.txt'
try:
    with open(path, 'r') as f:
        # 读取文件内容
except FileNotFoundError:
    print('File not found!')
except Exception as e:
    print('Error:', e)

Ce bloc de code peut intercepter FileNotFoundError et d'autres exceptions. Si le fichier est introuvable, le programme affichera un message d'erreur ; s'il rencontre d'autres exceptions, il affichera également un message d'erreur et enregistrera le type d'exception.

  1. Utiliser le mode binaire

Dans certains cas, vous devrez peut-être utiliser le mode binaire lors de la lecture de fichiers, comme la lecture d'images, de sons, etc. .fichier binaire. Lorsque vous utilisez le mode binaire, vous devez utiliser l'identifiant « b » dans le mode d'ouverture du fichier, comme indiqué ci-dessous :

path = 'image.png'
with open(path, 'rb') as f:
    # 读取二进制文件内容

Ici, «image.png» est le nom du fichier image et «rb» signifie mode binaire pour ouvrir le fichier. Lors de la lecture d'un fichier binaire, vous pouvez convertir le contenu lu en un tableau d'octets pour un traitement continu.

  1. Éviter le codage en dur

Lors de l'écriture de code, éviter de coder en dur les noms et chemins de fichiers peut rendre le code plus flexible et plus maintenable. Les chemins de fichiers peuvent être spécifiés à l'aide de fichiers de configuration, de paramètres de ligne de commande, etc. pour rendre le code plus polyvalent. Le fichier de configuration peut contenir plusieurs chemins de fichiers et le code peut choisir l'un des chemins à lire en fonction de la situation pour éviter les problèmes de codage en dur.

  1. Éviter les problèmes de sécurité

Lors de la lecture d'un fichier, vous pouvez être attaqué par un code malveillant dans le fichier. Par exemple, les fichiers lus peuvent contenir des scripts malveillants, des virus, etc. Pour éviter les problèmes de sécurité, les autorisations appropriées doivent être utilisées pour restreindre la lecture, l'écriture et d'autres opérations des fichiers. De plus, vous pouvez également utiliser des bibliothèques tierces, telles que PyPDF2, Pillow, python-docx, etc., pour lire des types spécifiques de fichiers afin d'éviter les risques de sécurité causés par la lecture directe de fichiers.

Résumé

En Python, la lecture de fichiers est une opération courante. Cependant, pendant le processus de lecture des fichiers, les rédacteurs de code peuvent commettre des erreurs, ce qui entraîne des méthodes de lecture non standard, entraînant des plantages du programme, une perte de temps et même des risques de sécurité. Pour éviter ces problèmes, utilisez des chemins absolus, vérifiez si le fichier existe, utilisez des instructions with, utilisez des blocs try-sauf, utilisez le mode binaire, évitez le codage en dur et évitez les problèmes de sécurité. Ces méthodes peuvent rendre le code plus standardisé, correct, maintenable et sûr.

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!

Déclaration:
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