Maison >développement back-end >Tutoriel Python >Pourquoi ma recherche de chaîne Python dans un fichier texte renvoie-t-elle toujours True ?

Pourquoi ma recherche de chaîne Python dans un fichier texte renvoie-t-elle toujours True ?

Susan Sarandon
Susan Sarandonoriginal
2024-12-22 02:14:21919parcourir

Why Does My Python String Search in a Text File Always Return True?

Recherche de chaînes dans des fichiers texte

Problème :
Une tentative de déterminer si une chaîne spécifique existe dans un fichier texte utilisant une fonction particulière renvoie toujours True quelle que soit la chaîne présence.

Code :

def check():
    datafile = file('example.txt')
    found = False
    for line in datafile:
        if blabla in line:
            found = True
            break

Diagnostic et solution :

Le code fourni boucle à travers les lignes du fichier texte et vérifie ligne par ligne la présence d'une chaîne spécifique, "blabla". Cependant, le problème réside dans la condition de blabla. En Python, in vérifie l'appartenance, ce qui signifie qu'il renvoie True si la chaîne se trouve n'importe où dans la ligne.

Pour atténuer ce problème, différentes approches peuvent être envisagées :

Option 1 : Recherche directe de chaîne dans le contenu du fichier

with open('example.txt') as f:
    if 'blabla' in f.read():
        print("true")

Cette approche lit l'intégralité du contenu du fichier dans une chaîne, puis vérifie la présence de la chaîne. Si le fichier n'est pas trop volumineux, cette méthode est souvent plus rapide et plus pratique que de parcourir chaque ligne.

Option 2 : Utiliser le mappage de mémoire pour un accès efficace aux fichiers

import mmap

with open('example.txt') as f:
    s = mmap.mmap(f.fileno(), 0, access=mmap.ACCESS_READ)
    if s.find('blabla') != -1:
        print('true')

Cette approche utilise la technique de mappage de mémoire de Python pour créer un objet « de type chaîne » qui manipule directement le fichier sous-jacent, permettant un accès efficace sans charger complètement le fichier dans mémoire.

Option 3 : Recherche insensible à la casse avec des expressions régulières

if re.search(br'(?i)blabla', s):
    print('true')

Cette approche utilise des expressions régulières pour effectuer une recherche insensible à la casse dans la mémoire mappée déposer. La syntaxe (?i)blabla fait que la recherche ignore les différences de casse.

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