Heim Backend-Entwicklung Python-Tutorial Wie kann ich Dateien mit fester Breite in Python effizient analysieren: Strukturmodul vs. optimiertes String-Slicing?

Wie kann ich Dateien mit fester Breite in Python effizient analysieren: Strukturmodul vs. optimiertes String-Slicing?

Oct 31, 2024 pm 03:43 PM

How to Efficiently Parse Fixed Width Files in Python: Struct Module vs. Optimized String Slicing?

Effizientes Parsen von Dateien mit fester Breite

Dateien mit fester Breite stellen aufgrund ihrer vorgegebenen Spaltenlängen eine einzigartige Parsing-Herausforderung dar. Für die Datenverarbeitung ist es von entscheidender Bedeutung, effiziente Wege zum Extrahieren von Daten aus solchen Dateien zu finden.

Problemstellung

Gegeben sei eine Datei mit Zeilen fester Breite, wobei jede Spalte einen bestimmten Wert darstellt , entwickeln Sie eine effiziente Methode, um diese Zeilen in separate Komponenten zu zerlegen. Derzeit wird String-Slicing eingesetzt, es bestehen jedoch Bedenken hinsichtlich der Lesbarkeit und Eignung für große Dateien.

Lösung

Es werden zwei effiziente Parsing-Methoden vorgestellt:

Methode 1: Verwenden des Strukturmoduls

Das Strukturmodul der Python-Standardbibliothek bietet eine praktische Möglichkeit, Daten aus binären Datenströmen zu entpacken. Es kann mit Dateien mit fester Breite verwendet werden, indem eine Formatzeichenfolge definiert wird, die die Breite und den Typ jedes Felds angibt. Diese Methode bietet sowohl Geschwindigkeit als auch Einfachheit.

Beispiel:

<code class="python">import struct

fieldwidths = (2, -10, 24)
fmtstring = ' '.join('{}{}'.format(abs(fw), 'x' if fw < 0 else 's') for fw in fieldwidths)

# Convert Unicode input to bytes and the result back to Unicode string.
unpack = struct.Struct(fmtstring).unpack_from  # Alias.
parse = lambda line: tuple(s.decode() for s in unpack(line.encode()))

print('fmtstring: {!r}, record size: {} chars'.format(fmtstring, struct.calcsize(fmtstring)))

line = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789\n'
fields = parse(line)
print('fields: {}'.format(fields))</code>
Nach dem Login kopieren

Methode 2: String-Slicing mit Kompilierung verwenden

Während das String-Slicing unkompliziert erscheinen mag, kann seine Geschwindigkeit verbessert werden, indem eine effizientere Version mit eval() kompiliert wird. Diese Methode generiert eine Liste von Slice-Grenzen, die konstant sind und daher schneller ausgeführt werden können.

Beispiel (optimiert):

<code class="python">def make_parser(fieldwidths):
    cuts = tuple(cut for cut in accumulate(abs(fw) for fw in fieldwidths))
    pads = tuple(fw < 0 for fw in fieldwidths) # bool flags for padding fields
    flds = tuple(zip_longest(pads, (0,)+cuts, cuts))[:-1]  # ignore final one
    slcs = ', '.join('line[{}:{}]'.format(i, j) for pad, i, j in flds if not pad)
    parse = eval('lambda line: ({})\n'.format(slcs))  # Create and compile source code.
    # Optional informational function attributes.
    parse.size = sum(abs(fw) for fw in fieldwidths)
    parse.fmtstring = ' '.join('{}{}'.format(abs(fw), 'x' if fw < 0 else 's')
                                                for fw in fieldwidths)
    return parse</code>
Nach dem Login kopieren

Beide Methoden bieten effiziente Möglichkeiten zum Parsen Dateien mit fester Breite. Methode 1 mit dem Strukturmodul ist einfach zu verwenden, während Methode 2 mit optimiertem String-Slicing bei Optimierung eine etwas bessere Leistung bietet.

Das obige ist der detaillierte Inhalt vonWie kann ich Dateien mit fester Breite in Python effizient analysieren: Strukturmodul vs. optimiertes String-Slicing?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden Mar 05, 2025 am 09:58 AM

So verwenden Sie Python, um die ZiPF -Verteilung einer Textdatei zu finden

So herunterladen Sie Dateien in Python So herunterladen Sie Dateien in Python Mar 01, 2025 am 10:03 AM

So herunterladen Sie Dateien in Python

Bildfilterung in Python Bildfilterung in Python Mar 03, 2025 am 09:44 AM

Bildfilterung in Python

Wie benutze ich eine schöne Suppe, um HTML zu analysieren? Wie benutze ich eine schöne Suppe, um HTML zu analysieren? Mar 10, 2025 pm 06:54 PM

Wie benutze ich eine schöne Suppe, um HTML zu analysieren?

Wie man mit PDF -Dokumenten mit Python arbeitet Wie man mit PDF -Dokumenten mit Python arbeitet Mar 02, 2025 am 09:54 AM

Wie man mit PDF -Dokumenten mit Python arbeitet

Wie kann man mit Redis in Django -Anwendungen zwischenstrichen Wie kann man mit Redis in Django -Anwendungen zwischenstrichen Mar 02, 2025 am 10:10 AM

Wie kann man mit Redis in Django -Anwendungen zwischenstrichen

Einführung des natürlichen Sprach -Toolkits (NLTK) Einführung des natürlichen Sprach -Toolkits (NLTK) Mar 01, 2025 am 10:05 AM

Einführung des natürlichen Sprach -Toolkits (NLTK)

Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch? Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch? Mar 10, 2025 pm 06:52 PM

Wie führe ich ein tiefes Lernen mit Tensorflow oder Pytorch durch?

See all articles