Inhaltsverzeichnis
Richtige Antwort
Heim Backend-Entwicklung Golang Die Golang-Funktion kann den Dateinamen nicht richtig lesen

Die Golang-Funktion kann den Dateinamen nicht richtig lesen

Feb 06, 2024 am 11:18 AM

Die Golang-Funktion kann den Dateinamen nicht richtig lesen

Frageninhalt

Ich habe also ein Repository mit mehreren CSV-Dateien, die das Tabellenschema der Datenbank enthalten. Ich habe einen Golang-Code geschrieben, der eine Liste von Dateinamen aus einem Repository abruft, diese Dateien dann öffnet, den Inhalt liest und eine MySQL CREATE-Abfrage erstellt.

Das Problem, mit dem ich konfrontiert bin, besteht darin, dass der Golang-Code bei einigen CSV-Dateien die Header letztendlich falsch liest, was später zu Problemen führt. Beispielsweise gibt es Dateien mit den Namen config_hr.csv, config_oe.csv, contribution_analysis.csv, die als onfig_hr.csv, onfig_oe.csv, contribution_analysi.csv gelesen werden. Dieses Problem schien gelöst zu sein, wenn ich den Namen großgeschrieben hätte, aber in den späteren Phasen unseres Projekts würden viele andere Probleme auftauchen.

Ist das ein Codierungsproblem? Ich habe den Code unter Windows, Mac und Linux überprüft und die Golang-Version ist die neueste Version 1.21. Für jede Hilfe oder Einsicht wäre ich sehr dankbar!

Golang-Code-Snippet zum Lesen des CSV-Dateinamens

entries, err := FileEntry.Readdir(0)
    if err != nil {
        log.Fatal(err)
    }

    // Now, open all the files one by one, and extract the content of the files.
    // Then modify the resultant string to be of MySQL compatibility.
    for _, e := range entries {
        // Mimicking the SQL Query of Table Creation query.
        Query_String := ("CREATE TABLE IF NOT EXISTS " + strings.ToLower(strings.Trim(strings.Replace(e.Name(), " ", "_", -1), ".csv")) + " (\n")
        fmt.Println("Opening -- " + file_folder + "/" + e.Name())
        file, err := os.Open(file_folder + "/" + e.Name())
        if err != nil {
            log.Fatal(err)
        }
        defer file.Close()
        // Reading the CSV file from path.
        reader := csv.NewReader(file)
        records, err := reader.ReadAll()
        if err != nil {
            log.Fatal(err)
        }


Richtige Antwort


Ersetzen Sie die Funktion string.Trim durch die folgende Funktion.

// getFileNameWithoutExtension takes a file path as input and returns
// the file name without its extension. It utilizes the filepath package
// to extract the base name and then removes the extension.
func getFileNameWithoutExtension(filePath string) string {
    // Get the base name of the file path (including extension)
    baseName := filepath.Base(filePath)

    // Calculate the length to remove the extension from the base name
    // and obtain the file name without extension
    fileNameWithoutExtension := baseName[:len(baseName)-len(filepath.Ext(baseName))]

    // Return the file name without extension
    return fileNameWithoutExtension
}

Beispielcode:

 Query_String := ("CREATE TABLE IF NOT EXISTS " + strings.ToLower(getFileNameWithoutExtension(strings.Replace(e.Name(), " ", "_", -1))) + " (\n")

Das obige ist der detaillierte Inhalt vonDie Golang-Funktion kann den Dateinamen nicht richtig lesen. 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

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

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.

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

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

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)

Heiße Themen

PHP-Tutorial
1510
276
Gehen Sie für Audio-/Videoverarbeitung Gehen Sie für Audio-/Videoverarbeitung Jul 20, 2025 am 04:14 AM

Der Kern der Audio- und Videoverarbeitung liegt darin, die grundlegenden Prozess- und Optimierungsmethoden zu verstehen. 1. Der grundlegende Prozess umfasst Akquisition, Codierung, Übertragung, Decodierung und Wiedergabe, und jeder Link hat technische Schwierigkeiten. 2. Häufige Probleme wie Audio- und Video -Aberration, Verzögerungsverzögerung, Schallgeräusch, verschwommenes Bild usw. können durch synchrone Einstellung, Codierungsoptimierung, Rauschverringerungsmodul, Parameteranpassung usw. gelöst werden; 3.. Es wird empfohlen, FFMPEG, OpenCV, Webrtc, Gstreamer und andere Tools zu verwenden, um Funktionen zu erzielen. 4. In Bezug auf das Leistungsmanagement sollten wir auf die Beschleunigung der Hardware, die angemessene Einstellung der Auflösungsrahmenquoten, die Kontrollverkehr und Speicher -Leckage -Probleme achten. Wenn Sie diese wichtigen Punkte beherrschen, werden die Entwicklungseffizienz und die Benutzererfahrung verbessert.

Entwicklung von Kubernetes -Betreibern in Go Entwicklung von Kubernetes -Betreibern in Go Jul 25, 2025 am 02:38 AM

Der effizienteste Weg, um einen Kubernetesoperator zu schreiben, besteht darin, GO zu verwenden, um Kubebuilder und Controller-Runtime zu kombinieren. 1. Verstehen Sie das Bedienermuster: Definieren Sie benutzerdefinierte Ressourcen über CRD, schreiben Sie einen Controller, um auf Ressourcenänderungen zu hören und Versöhnungsschleifen durchzuführen, um den erwarteten Zustand aufrechtzuerhalten. 2. Verwenden Sie Kubebuilder, um das Projekt zu initialisieren und APIs zu erstellen, um automatisch CRDs, Controller und Konfigurationsdateien zu generieren. 1. Definieren Sie die Spezifikation und die Statusstruktur von CRD in API/v1/myapp_types.go und führen Sie MakeManifests aus, um Crdyaml zu generieren. 4.. Versöhnung im Controller

GO -Abfrageoptimierungstechniken für PostgreSQL/MySQL GO -Abfrageoptimierungstechniken für PostgreSQL/MySQL Jul 19, 2025 am 03:56 AM

TooptimizeGoapplicationssinteractingwithpostgresqlormysql, FocusonIndexing, Selektivquerien, Verbindungshandling, Caching, Andormeffizienz.1) UseProperIndexing-IdentifizierfrequentqueriedColumns, addIndexesselektiv, andusecomposeFrequent-Formulti-kolumnquerquer

Gehen Sie für wissenschaftliches Computer und numerische Analyse Gehen Sie für wissenschaftliches Computer und numerische Analyse Jul 23, 2025 am 01:53 AM

GO -Sprache kann für wissenschaftliche Berechnungen und numerische Analysen verwendet werden, muss jedoch verstanden werden. Der Vorteil liegt in der Parallelitätsunterstützung und -leistung, die für parallele Algorithmen wie verteilte Lösung, Monte -Carlo -Simulation usw. geeignet ist; Community -Bibliotheken wie Gonum und MAT64 bieten grundlegende numerische Berechnungsfunktionen; Hybridprogrammierung kann verwendet werden, um C/C und Python über CGO oder Schnittstelle aufzurufen, um die Praktikabilität zu verbessern. Die Einschränkung besteht darin, dass das Ökosystem nicht so reif ist wie Python, die Visualisierung und die erweiterten Tools schwächer und einige Bibliotheksdokumente unvollständig sind. Es wird empfohlen, geeignete Szenarien basierend auf GO -Funktionen auszuwählen und sich auf die Beispiele für Quellcode zu verweisen, um sie ausführlich zu verwenden.

Gehen Sie für Bildmanipulationsbibliotheken Gehen Sie für Bildmanipulationsbibliotheken Jul 21, 2025 am 12:23 AM

Common GO-Bildverarbeitungsbibliotheken umfassen Standardbibliotheksbildpakete und Bibliotheken von Drittanbietern wie Bildgebung, BIMG und Imagick. 1. Das Bildpaket ist für grundlegende Operationen geeignet. 2. Die Bildgebung hat eine vollständige Funktion und eine einfache API, die für die meisten Bedürfnisse geeignet ist. 3. Bimg basiert auf libvips, hat eine starke Leistung, die für große Bilder oder hohe Parallelität geeignet ist. 4. Imagick bindet Imagemagick, das mächtig ist, aber schwere Abhängigkeiten hat. Implementieren Sie schnell Bildskalierung und Kumpel. Sie können die Bildgebungsbibliothek verwenden, um sie durch einige Codezeilen in der Größe der Größe und der Cropanchor -Funktionen zu vervollständigen und mehrere Parameterkonfigurationen zu unterstützen. Hinzufügen von Filtern oder Anpassungstönen kann durch die durch Vorstellungskraft bereitgestellte Farbtransformationsfunktion wie Graysc erreicht werden

Stack vs Heap Allocation mit Zeigern in Go Stack vs Heap Allocation mit Zeigern in Go Jul 23, 2025 am 04:14 AM

Die Stapelzuweisung ist für kleine lokale Variablen mit klaren Lebenszyklen geeignet und wird automatisch mit schneller Geschwindigkeit, aber vielen Einschränkungen verwaltet. Die Haufen Allokation wird für Daten mit langen oder unsicheren Lebenszyklen verwendet und ist flexibel, hat jedoch Leistungskosten. Der Go -Compiler bestimmt automatisch die variable Zuordnungsposition durch Escape -Analyse. Wenn die Variable dem aktuellen Funktionsbereich entkommen kann, wird sie dem Haufen zugewiesen. Zu den häufigen Situationen, die Flucht verursachen, gehören: Rückgabe lokaler variabler Zeiger, Zuordnen von Werten für Schnittstellentypen und Übergeben von Goroutinen. Die Ergebnisse der Escape Analysis können durch -gcflags = " -m" betrachtet werden. Bei der Verwendung von Zeigern sollten Sie auf den variablen Lebenszyklus achten, um unnötige Flucht zu vermeiden.

Lesen von Stdin in Go durch Beispiel Lesen von Stdin in Go durch Beispiel Jul 27, 2025 am 04:15 AM

Verwenden Sie FMT.Scanf, um formatierte Eingaben zu lesen, die für einfache strukturierte Daten geeignet sind. Die Zeichenfolge wird jedoch bei der Begegnung von Räumen abgeschnitten. 2. Es wird empfohlen, bufio.scanner zum Lesen von Zeile für die Zeile zu verwenden, unterstützt Multi-Line-Ein-, EOF-Erkennung und Pipeline-Eingang und kann Scanfehler verarbeiten. 3. Verwenden Sie IO.Readall (OS.Stdin), um alle Eingaben gleichzeitig zu lesen, die für die Verarbeitung großer Blockdaten oder Dateiströme geeignet sind. 4. Echtzeit-Schlüsselantwort erfordert Bibliotheken von Drittanbietern wie golang.org/x/term, und Bufio reicht für herkömmliche Szenarien aus. Praktische Vorschläge: Verwenden Sie FMT.Scan für die interaktive einfache Eingabe, verwenden Sie bufio.scanner für die Linieneingabe oder -pipeline, verwenden

Wie erholt man mich von einer Panik in Go? Wie erholt man mich von einer Panik in Go? Jul 23, 2025 am 04:11 AM

Panik ist wie ein Programm "Herzinfarkt" in Go. Wiederherstellung kann als "Erste -Hilfe -Tool" verwendet werden, um Abstürze zu verhindern, aber die Wiederherstellung nur in der Aufhebungsfunktion wirkt. 1. Recover wird verwendet, um Dienstverlagerung, Protokollprotokolle zu vermeiden und freundliche Fehler zurückzugeben. 2. Es muss in Verbindung mit dem Aufschub verwendet werden und wirkt sich nur auf dieselbe Goroutine aus. Das Programm kehrt nach der Genesung nicht zum Panikpunkt zurück. 3.. Es wird empfohlen, es auf der oberen Ebene oder im kritischen Eingang zu verwenden und es nicht zu missbrauchen und die Verwendung der Fehlerverarbeitung Priorität zu geben. 4. Das gemeinsame Muster besteht darin, Saferun -Funktionen zu verkapulieren, um eine mögliche Paniklogik zu wickeln. Nur indem sie seine Nutzungsszenarien und Einschränkungen beherrschen, kann es seine Rolle korrekt spielen.

See all articles