Одна вещь, которая делает библиотеку Clojure такой мощной, — это количество библиотек, доступных для платформы Clojure. Мы уже видели так много библиотек, которые использовались в наших предыдущих примерах для веб-тестирования, веб-разработки, разработки основанных на свинге приложений, библиотеки jdbc для подключения к базам данных MySQL. Ниже приведены лишь несколько примеров нескольких библиотек.
data.xml
Эта библиотека позволяет Clojure работать с данными XML. Используемая версия библиотеки: org.clojure / data.xml «0.0.8». Data.xml поддерживает синтаксический анализ и передачу XML. Функции синтаксического анализа будут читать XML из Reader или InputStream.
пример
Ниже приведен пример обработки данных из строки в XML.
(ns clojure.examples.example (use 'clojure.data.xml) (:gen-class)) (defn Example [] (let [input-xml (java.io.StringReader. "<?xml version = \"1.0\" encoding = \"UTF-8\"?><example><clo><Tutorial>The Tutorial value</Tutorial></clo></example>")] (parse input-xml))) #clojure.data.xml.Element{ :tag :example, :attrs {}, :content (#clojure.data.xml.Element { :tag :clo, :attrs {}, :content (#clojure.data.xml.Element { :tag :Tutorial, :attrs {},:content ("The Tutorial value")})})} (Example)
data.json
Эта библиотека позволяет Clojure работать с данными JSON. Используемая версия библиотеки — org.clojure / data.json «0.2.6».
пример
Ниже приведен пример использования этой библиотеки.
(ns clojure.examples.example (:require [clojure.data.json :as json]) (:gen-class)) (defn Example [] (println (json/write-str {:a 1 :b 2}))) (Example)
Выход
Вышеуказанная программа производит следующий вывод.
{\"a\":1,\"b\":2}
data.csv
Эта библиотека позволяет Clojure работать с данными ‘csv’ . Используемая версия библиотеки — org.clojure / data.csv «0.1.3».
пример
Ниже приведен пример использования этой библиотеки.
(ns clojure.examples.example (require '[clojure.data.csv :as csv] '[clojure.java.io :as io]) (:gen-class)) (defn Example [] (with-open [in-file (io/reader "in-file.csv")] (doall (csv/read-csv in-file))) (with-open [out-file (io/writer "out-file.csv")] (csv/write-csv out-file [[":A" "a"] [":B" "b"]]))) (Example)
В приведенном выше коде функция ‘csv’ сначала прочитает файл in-file.csv и поместит все данные в переменную in-file. Далее мы используем функцию write-csv для записи всех данных в файл с именем out-file.csv.