clojure实战——IO(1)
本博客主要介绍clojure基本文件处理。除了clojure.core单元,还主要用到clojure.java.io单元。在实践本博客中的示例时,可以在repl中require相应命名空间:
(require '[clojure.java.io :as cio])
(require '[clojure.edn :as edn])
读取一个文本文件的全部内容
clojure.core/slurp
读取一个文件的全部内容,并以字符串形式返回,
示例:
(comment
(slurp "files/file-test.txt" :encoding "UTF-8")
;; => "a txt file line1\na txt file line2\n这是中文字符"
)
逐行读取文件内容
clojure.core/line-seq
line-seq将逐行读取文件内容,并返回一个字符串的lazy序列,只有真正使用到的时候,才执行读取操作
示例:
(comment
(defn read-by-line
"line-fn:处理一行数据的函数"
[file-path line-fn]
(with-open [^java.io.BufferedReader rdr (cio/reader file-path :encoding "UTF-8")]
(doseq [a (line-seq rdr)]
(line-fn a))))
(read-by-line "files/file-test.txt" (partial println "a line ===== "))
;; => ["a txt file line1" "a txt file line2" "这是中文字符"]
)
写文件
clojure.core/spit [file-path content & options]
file-path:为文件路径;
content:为要写入文件的内容,所有的内容都会被转为String类型写入。
options:一些设置参数,常见的有:
- :append true/false;当为true是,内容会从文件后面写入,如果要换行写入,需要在内容后面加入\n换行符,当为false时,会擦掉文件原有的内容。
- :encoding “UTF-8”或”GBK”等。 默认是UTF-8.
spit函数会先打开文件,再将内容写入,再关闭文件。
spit都是以字符串形式写入。
示例:
(comment
(spit "files/file-test.txt" "新增文件内容\n" :append false :encoding "GBK")
(slurp "files/file-test.txt" :encoding "GBK")
;; => "新增文件内容\n"
(slurp "files/file-test.txt" :encoding "UTF-8")
;; => "�����ļ�����\n"
(spit "files/file-test.txt" "新增文件内容\n" :append false)
(slurp "files/file-test.txt" :encoding "GBK")
;; => "鏂板鏂囦欢鍐呭\n"
(slurp "fil