Clojure:
Arbeta med CSV
Hur man gör:
Läsa en CSV-fil
Clojure har ingen inbyggd CSV-tolkning i sitt standardbibliotek, men du kan använda clojure.data.csv
-biblioteket för detta ändamål. Lägg först till biblioteket i dina projektberoenden.
I din project.clj
, lägg till följande beroende:
[clojure.data.csv "1.0.0"]
För att läsa en CSV-fil och skriva ut varje rad:
(require '[clojure.data.csv :as csv]
'[clojure.java.io :as io])
(with-open [reader (io/reader "path/to/yourfile.csv")]
(doall
(map println (csv/read-csv reader))))
Detta kommer att skriva ut varje rad av CSV-filen som en Clojure-vektor.
Skriva till en CSV-fil
För att skriva data till en CSV-fil kan du använda samma clojure.data.csv
-bibliotek:
(require '[clojure.data.csv :as csv]
'[clojure.java.io :as io])
(let [data [["id" "name" "age"]
["1" "John Doe" "28"]
["2" "Jane Doe" "31"]]]
(with-open [writer (io/writer "path/to/outputfile.csv")]
(csv/write-csv writer data)))
Detta skapar eller skriver över outputfile.csv
, och fyller den med den specificerade datan.
Använda ett tredjepartsbibliotek: clojure.data.csv
Även om clojure.data.csv
är det kanske mest okomplicerade biblioteket för hantering av CSV i Clojure, för mer komplexa uppgifter, såsom hantering av CSV-filer med speciella tecken eller oortodoxa avgränsare, kan du utforska ytterligare alternativ inom ekosystemet eller till och med överväga Java-interoperabilitet med bibliotek som Apache Commons CSV. Dock, för de flesta standardiserade CSV-behandlingsuppgifter i Clojure, tillhandahåller clojure.data.csv
en enkel och effektiv verktygslåda.