• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-19  評論-21  文章-0  trackbacks-0

            lisp的功能還是挺強大的,簡單的幾十行代碼就搞定了一個小的“數據庫”(經驗:調試macro的時候可以用macroexpand-1展開該macro,看是否與設想的一樣)。

            感受一下lisp吧:

            CL-USER> (load "D:/database.lisp")
            T
            CL-USER> (add-cds)
            Title: hacker
            Artist: PG
            Rating: 10
            
            Ripped[y/n]:  (y or n) y
            
            Another? [y/n]:  (y or n) n
            NIL
            CL-USER> (save-db "D:/save.db")
            ((:TITLE "hacker" :ARTIST "PG" :RATING 10 :RIPPED T))
            CL-USER> (add-cds)
            Title: painter
            Artist: PG
            Rating: 10
            
            Ripped[y/n]:  (y or n) y
            
            Another? [y/n]:  (y or n) n
            NIL
            CL-USER> (dump-db)
            TITLE: painter
            ARTIST:   PG
            RATING:   10
            RIPPED:   T
            
            TITLE:    hacker
            ARTIST:   PG
            RATING:   10
            RIPPED:   T
            
            NIL
            CL-USER> (select (where :title "hacker"))
            ((:TITLE "hacker" :ARTIST "PG" :RATING 10 :RIPPED T))
            CL-USER> (update (where :title "painter") :title "paint")
            ((:TITLE "paint" :ARTIST "PG" :RATING 10 :RIPPED T)
                      (:TITLE "hacker" :ARTIST "PG" :RATING 10 :RIPPED T))
            代碼出自practical common lisp 一書,有改動~
            (defvar?*db*?nil)

            (defun?make
            -cd?(title?artist?rating?ripped)
            ??(list?:title?title?:artist?artist?:rating?rating?:ripped?ripped))

            (defun?add
            -record?(cd)?(push?cd?*db*))

            (defun?dump
            -db?()
            ??(dolist?(cd?
            *db*)
            ????(format?t?
            "~{~a:~10t~a~%~}~%"?cd)))

            (defun?prompt
            -read?(prompt)
            ??(format?
            *query-io*?"~a:?"?prompt)
            ??(force
            -output?*query-io*)
            ??(read
            -line?*query-io*))

            (defun?prompt
            -for-cd?()
            ??(make
            -cd?
            ???(prompt
            -read?"Title")
            ???(prompt
            -read?"Artist")
            ???(or?(parse
            -integer?(prompt-read?"Rating")?:junk-allowed?t)?0)
            ???(y
            -or-n-p?"Ripped[y/n]:?")))

            (defun?add
            -cds?()
            ??(loop?(add
            -record?(prompt-for-cd))
            ?????(
            if?(not?(y-or-n-p?"Another??[y/n]:?"))?(return))))

            (defun?save
            -db?(filename)
            ??(with
            -open-file?(out?filename?:direction?:output?:if-exists?:supersede)
            ????(with
            -standard-io-syntax
            ??????(print?
            *db*?out))))

            (defun?load
            -db?(filename)
            ??(with
            -open-file?(in?filename)
            ????(with
            -standard-io-syntax
            ??????(setf?
            *db*?(read?in)))))

            (defun?select?(selector
            -fn)
            ??(remove
            -if-not?selector-fn?*db*))

            (defun?make
            -comparison-expr?(field?value)
            ??`(equal?(getf?cd?,field)?,value))

            (defun?make
            -comparisons-list?(fields)
            ??(loop?
            while?fields
            ???????collecting?(make
            -comparison-expr?(pop?fields)?(pop?fields))))

            (defmacro?where?(
            &rest?clauses)
            ??`#
            '(lambda?(cd)?(and?,@(make-comparisons-list?clauses))))

            ;(defun?where?(
            &key?title?artist?rating?(ripped?nil?ripped-p))
            ;??#
            '(lambda?(cd)
            ;??????(and
            ;???????(
            if?title????(equal?(getf?cd?:title)?title)?t)
            ;???????(
            if?artist???(equal?(getf?cd?:artist)?artist)?t)
            ;???????(
            if?rating???(equal?(getf?cd?:rating)?rating)?t)
            ;???????(
            if?ripped-p?(equal?(getf?cd?:ripped)?ripped)?t))))

            (defun?make
            -set-expr?(field?value)
            ??`(setf?(getf?row?,field)?,value))

            (defun?make
            -set-list?(fields)
            ??(loop?
            while?fields
            ???????collecting?(make
            -set-expr?(pop?fields)?(pop?fields))))

            (defmacro?update?(selector
            -fn?&rest?clauses)
            ??`(setf?
            *db*
            ?????(mapcar
            ?????#
            '(lambda?(row)?
            ?????????(when?(funcall?,selector-fn?row)?,@(make-set-list?clauses))
            ?????????row)?
            *db*)))
            ?????

            ;(defun?update?(selector
            -fn?&key?title?artist?rating?(ripped?nil?ripped-p))
            ;??(setf?
            *db*
            ;????(mapcar
            ;?????#
            '(lambda?(row)
            ;?????????(when?(funcall?selector-fn?row)
            ;???????????(
            if?title????(setf?(getf?row?:title)?title))
            ;???????????(
            if?artist???(setf?(getf?row?:artist)?artist))
            ;???????????(
            if?rating???(setf?(getf?row?:rating)?rating))
            ;???????????(
            if?ripped-p?(setf?(getf?row?:ripped)?ripped)))
            ;?????????row)?
            *db*)))

            (defun?delete
            -rows?(selector-fn)
            ??(setf?
            *db*?(remove-if?selector-fn?*db*)))

            posted on 2010-10-01 22:23 hex108 閱讀(1014) 評論(0)  編輯 收藏 引用 所屬分類: Lisp
            日产精品久久久久久久| 大美女久久久久久j久久| 香蕉久久夜色精品国产尤物| 中文字幕无码久久久| 奇米影视7777久久精品| 香蕉久久一区二区不卡无毒影院| 精品久久人人做人人爽综合 | 欧美一区二区三区久久综合| 色偷偷88888欧美精品久久久| 国产精品久久成人影院| 日韩va亚洲va欧美va久久| 久久久精品2019免费观看| 99久久精品国产高清一区二区| 久久久久亚洲av成人无码电影| 久久久久久精品成人免费图片| 热99re久久国超精品首页| 久久精品日日躁夜夜躁欧美| 精品一久久香蕉国产线看播放| 狼狼综合久久久久综合网| 中文字幕精品久久久久人妻| 国产精品久久久久久久久| 精品一二三区久久aaa片| 久久国产V一级毛多内射| 97久久香蕉国产线看观看| 精品人妻伦九区久久AAA片69| 国产成人精品久久综合| 国内精品久久久久久99蜜桃| 色悠久久久久久久综合网| 久久精品国产精品亜洲毛片| 久久成人国产精品| 亚洲AV日韩AV永久无码久久| 亚洲精品国产字幕久久不卡| 一本综合久久国产二区| 日韩中文久久| 亚洲国产精品综合久久一线| 久久亚洲2019中文字幕| 久久人人爽人人爽人人片AV麻豆 | 东京热TOKYO综合久久精品| 亚洲精品乱码久久久久久中文字幕 | 久久久精品国产亚洲成人满18免费网站 | 久久国产乱子伦免费精品|