Szukaj…
Wprowadzenie
Dokument ten dotyczy sposobu manipulowania datą i godziną w trybie clojure.
Aby użyć tego w aplikacji, przejdź do pliku project.clj i umieść [clj-time "<numer_wersji>”] w sekcji: zależności.
Tworzenie Joda Time
(clj-time/date-time 2017 1 20)
Daje ci czas Joda 20 stycznia 2017 o 00:00:00.
Godziny, minuty i sekundy można również określić jako
(clj-time/date-time year month date hour minute second millisecond)
Pobieranie Dzień Miesiąc Rok Godzina Minuta Sekunda od twojej daty i godziny
(require '[clj-time.core :as t])
(def example-time (t/date-time 2016 12 5 4 3 27 456))
(t/year example-time) ;; 2016
(t/month example-time) ;; 12
(t/day example-time) ;; 5
(t/hour example-time) ;; 4
(t/minute example-time) ;; 3
(t/second example-time) ;; 27
Porównywanie dwóch dat i godzin
(require '[clj-time.core :as t])
(def date1 (t/date-time 2016 12 5))
(def date2 (t/date-time 2016 12 6))
(t/equal? date1 date2) ;; false
(t/equal? date1 date1) ;; true
(t/before? date1 date2) ;; true
(t/before? date2 date1) ;; false
(t/after? date1 date2) ;; false
(t/after? date2 date1) ;; true
Sprawdzanie, czy czas mieści się w przedziale czasu
Ta funkcja informuje, czy dany czas mieści się w danym przedziale czasowym.
(require '[clj-time.core :as t])
(def date1 (t/date-time 2016 11 5))
(def date2 (t/date-time 2016 12 5))
(def test-date1 (t/date-time 2016 12 20))
(def test-date2 (t/date-time 2016 11 15))
(t/within? (t/interval date1 date2) test-date1) ;; false
(t/within? (t/interval date1 date2) test-date2) ;; true
Używana funkcja interwału ma charakter wyłączny , co oznacza, że nie zawiera drugiego argumentu funkcji w interwale. Jako przykład:
(t/within? (t/interval date1 date2) date2) ;; false
(t/within? (t/interval date1 date2) date1) ;; true
Dodawanie daty i godziny Joda z innych typów czasu
Biblioteka clj-time.coerce może pomóc w konwersji innych formatów daty i godziny na format czasu Joda (clj-time.core / date-time). Inne formaty obejmują długi format Java , ciąg , datę , datę SQL .
Aby przekonwertować czas z innych formatów czasu, dołącz bibliotekę i użyj funkcji from, np
(require '[clj-time.coerce :as c])
(def string-time "1990-01-29")
(def epoch-time 633571200)
(def long-time 633551400)
(c/from-string string-time) ;; #<DateTime 1990-01-29T00:00:00.000Z>
(c/from-epoch epoch-time) ;; #<DateTime 1990-01-29T00:00:00.000Z>
(c/from-long 633551400) ;; #<DateTime 1990-01-29T00:00:00.000Z>
Dodawanie daty i godziny do innych dat
cljs-time daje nam opcję dodawania / odejmowania dat od innych dat. Odejmowane czasy daty powinny mieć postać dni, miesięcy, lat, godzin itp.
(require '[clj-time.core :as t])
(def example-date (t/date-time 2016 1 1)) ;; #<DateTime 2016-01-01T00:00:00.000Z>
;; Addition
(t/plus example-date (t/months 1)) ;; #<DateTime 2016-02-01T00:00:00.000Z>
(t/plus example-date (t/years 1)) ;; #<DateTime 2017-01-01T00:00:00.000Z>
;; Subtraction
(t/minus example-date (t/days 1)) ;; #<DateTime 2015-12-31T00:00:00.000Z>
(t/minus example-date (t/hours 12)) ;; #<DateTime 2015-12-31T12:00:00.000Z>