clojure
クロージャーでログを解析する
サーチ…
レコードと正規表現を使ってログの行を解析する
(defrecord Logline [datetime action user id])
(def pattern #"(\d{8}-\d{2}:\d{2}:\d{2}.\d{3})\|.*\|(\w*),(\w*),(\d*)")
(defn parser [line]
(if-let [[_ dt a u i] (re-find pattern line)]
(->Logline dt a u i)))
サンプル行を定義する:
(def sample "20170426-17:20:04.005|bip.com|1.0.0|alert|Update,john,12")
試して :
(parser sample)
結果:
#user.Logline{:datetime "20170426-17:20:04.005", :action "Update", :user "john", :id "12"}
Modified text is an extract of the original Stack Overflow Documentation
ライセンスを受けた CC BY-SA 3.0
所属していない Stack Overflow