


Warum gibt meine Python-String-Suche in einer Textdatei immer „True' zurück?
Suchen nach Zeichenfolgen in Textdateien
Problem:
Ein Versuch, festzustellen, ob eine bestimmte Zeichenfolge darin vorhanden ist Eine Textdatei, die eine bestimmte Funktion verwendet, gibt unabhängig von der Zeichenfolge immer True zurück Präsenz.
Code:
def check(): datafile = file('example.txt') found = False for line in datafile: if blabla in line: found = True break
Diagnose und Lösung:
Der bereitgestellte Code durchläuft die Zeilen der Textdatei und prüft Zeile für Zeile, ob eine bestimmte Zeichenfolge, „blabla“, vorhanden ist. Das Problem liegt jedoch in der Bedingung, dass Blabla im Einklang steht. In Python prüft es die Mitgliedschaft, d. h. es gibt „True“ zurück, wenn sich die Zeichenfolge irgendwo in der Zeile befindet.
Um dieses Problem zu beheben, können verschiedene Ansätze in Betracht gezogen werden:
Option 1: Direkte Zeichenfolgensuche im Dateiinhalt
with open('example.txt') as f: if 'blabla' in f.read(): print("true")
Dieser Ansatz liest den gesamten Dateiinhalt in eine Zeichenfolge ein und prüft dann, ob die Zeichenfolge vorhanden ist. Wenn die Datei nicht zu groß ist, ist diese Methode oft schneller und bequemer als das Durchlaufen jeder Zeile.
Option 2: Speicherzuordnung für effizienten Dateizugriff verwenden
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')
Dieser Ansatz nutzt die Speicherzuordnungstechnik von Python, um ein „stringähnliches“ Objekt zu erstellen, das die zugrunde liegende Datei direkt manipuliert und so einen effizienten Zugriff ermöglicht, ohne die Datei vollständig zu laden Speicher.
Option 3: Suche ohne Berücksichtigung der Groß-/Kleinschreibung mit regulären Ausdrücken
if re.search(br'(?i)blabla', s): print('true')
Dieser Ansatz verwendet reguläre Ausdrücke, um eine Suche ohne Berücksichtigung der Groß-/Kleinschreibung innerhalb des zugeordneten Speichers durchzuführen Datei. Die Syntax (?i)blabla sorgt dafür, dass bei der Suche Groß- und Kleinschreibung ignoriert wird.
Das obige ist der detaillierte Inhalt vonWarum gibt meine Python-String-Suche in einer Textdatei immer „True' zurück?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

ForHandlinglargedatasetsinpython, Usenumpyarraysforbetterperformance.1) Numpyarraysarememory-Effiction und FasterFornumericaloperations.2) meidenunnötiger Anbieter.3) HebelVectorisationFecedTimeComplexity.4) ManagemememoryusageSageWithEffizienceDeffictureWitheseffizienz

Inpython, listEUSUutsynamicMemoryAllocationWithover-Accocation, whilenumpyarraysalcodeFixedMemory.1) ListSallocatemoremoryThanneded intellig, vereitelte, dass die sterbliche Größe von Zeitpunkte, OfferingPredictableSageStoageStloseflexeflexibilität.

Inpython, youcansspecthedatatypeyFelemeremodelerernspant.1) Usenpynernrump.1) Usenpynerp.dloatp.Ploatm64, Formor -Präzise -Preciscontrolatatypen.

NumpyisessentialfornumericalComputingInpythonduetoitsSpeed, GedächtnisEffizienz und kompetentiertemaMatematical-Funktionen.1) ITSFACTBECAUSPERFORMATIONSOPERATIONS.2) NumpyarraysSaremoremory-Effecthonpythonlists.3) iTofferSAgyarraysAremoremory-Effizieren

ContInuuousMemoryAllocationScrucialforAraysBecauseAltoLowsFofficy und Fastelement Access.1) iTenablesconstantTimeAccess, O (1), Duetodirectaddresscalculation.2) itimProvesefficienceByallowing -MultipleTeLementFetchesperCacheline.3) Es wird gestellt

SlicingPapythonListisDoneUsingthesyntaxlist [Start: Stop: Stufe] .here'Showitworks: 1) StartIndexoFtheFirstelementtoinclude.2) stopiStheIndexoFtheFirstelementtoexclude.3) StepisTheincrementBetweenelesfulFulForForforexcractioningPorporionsporporionsPorporionsporporesporsporsporsporsporsporsporsporsporionsporsPorsPorsPorsPorsporsporsporsporsporsporsAntionsporsporesporesporesporsPorsPorsporsPorsPorsporsporspors,

Numpyallowsforvariousoperationssonarrays: 1) BasicarithmeticliKeaddition, Subtraktion, Multiplikation und Division; 2) AdvancedoperationssuchasmatrixMultiplication;

Arraysinpython, insbesondere ThroughNumpyandpandas, areessentialfordataanalyse, öfterspeedandeffizienz.1) numpyarraysenableAnalysHandlingoflargedatasets und CompompexoperationslikemovingAverages.2) Pandasextendsnumpy'ScapaBilitiesWithDaTataforsForstruc


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

VSCode Windows 64-Bit-Download
Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

SAP NetWeaver Server-Adapter für Eclipse
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

mPDF
mPDF ist eine PHP-Bibliothek, die PDF-Dateien aus UTF-8-codiertem HTML generieren kann. Der ursprüngliche Autor, Ian Back, hat mPDF geschrieben, um PDF-Dateien „on the fly“ von seiner Website auszugeben und verschiedene Sprachen zu verarbeiten. Es ist langsamer und erzeugt bei der Verwendung von Unicode-Schriftarten größere Dateien als Originalskripte wie HTML2FPDF, unterstützt aber CSS-Stile usw. und verfügt über viele Verbesserungen. Unterstützt fast alle Sprachen, einschließlich RTL (Arabisch und Hebräisch) und CJK (Chinesisch, Japanisch und Koreanisch). Unterstützt verschachtelte Elemente auf Blockebene (wie P, DIV),
