Clojure Tutorial on Clojure File I/O

clojure provides a number of helper methods when working with i/o. it offers easier classes to provide the following functionalities for files.

  • reading files
  • writing to files
  • seeing whether a file is a file or directory

let’s explore some of the file operations clojure has to offer.

reading the contents of a file as an entire string

if you want to get the entire contents of the file as a string, you can use the clojure.core.slurp method. the slurp command opens a reader on a file and reads all its contents, returning a string.

following is an example of how this can be done.

(ns clojure.examples.hello
   (:gen-class))

;; this program displays hello world
(defn example []
   (def string1 (slurp "example.txt"))
   (println string1))
(example)

if the file contains the following lines, they will be printed as −

line : example1
line : example2

reading the contents of a file one line at a time

if you want to get the entire contents of the file as a string one line at a time, you can use the clojure.java.io/reader method. the clojure.java.io/reader class creates a reader buffer, which is used to read each line of the file.

following is an example that shows how this can be done.

(ns clojure.examples.hello
   (:gen-class))

;; this program displays hello world
(defn example []
   (with-open [rdr (clojure.java.io/reader "example.txt")]
   (reduce conj [] (line-seq rdr))))
(example)

if the file contains the following lines, they will be printed as −

line : example1
line : example2

the output will be shown as −

["line : example1" "line : example2"]

writing ‘to’ files

if you want to write ‘to’ files, you can use the clojure.core.spit command to spew entire strings into files. the spit command is the opposite of the slurp method. this method opens a file as a writer, writes content, then closes file.

following is an example.

(ns clojure.examples.hello
   (:gen-class))

;; this program displays hello world
(defn example []
   (spit "example.txt"
      "this is a string"))

in the above example, if you see the contents of the example.txt file , you will see the contents of “this is a string”.

writing ‘to’ files one line at a time

if you want to write ‘to’ files one line at a time, you can use the clojure.java.io.writer class. the clojure.java.io.writer class is used to create a writer stream wherein bytes of data are fed into the stream and subsequently into the file.

following is an example that shows how the spit command can be used.

(ns clojure.examples.hello
   (:gen-class))

;; this program displays hello world
(defn example []
   (with-open [w (clojure.java.io/writer "example.txt" :append true)]
      (.write w (str "hello" "world"))))
(example)

when the above code is executed, the line “hello world” will be present in the example.txt file. the append:true option is to append data to the file. if this option is not specified, then the file will be overwritten whenever data is written to the file.

checking to see if a file exists

to check if a file exists, the clojure.java.io.file class can be used to check for the existence of a file. following is an example that shows how this can be accomplished.

(ns clojure.examples.hello
   (:gen-class))

;; this program displays hello world
(defn example []
   (println (.exists (clojure.java.io/file "example.txt"))))
(example)

if the file example.txt exists, the output will be true.

reading from the console

to read data from the console, the read-line statement can be used. following is an example that shows how this can be used.

if you enter the (read-line) command in the repl window, you will have the chance to enter some input in the console window.

user->(read-line)
hello world

the above code will produce the following output.

“hello world”