• <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 閱讀(1008) 評論(0)  編輯 收藏 引用 所屬分類: Lisp
            日产精品99久久久久久| 亚洲狠狠婷婷综合久久久久| 国产69精品久久久久9999| 久久精品国产国产精品四凭 | 97视频久久久| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 日韩电影久久久被窝网| 久久久亚洲欧洲日产国码是AV | 久久青青草原精品国产| 久久精品无码免费不卡| 久久国产精品无码一区二区三区| 精品久久久无码中文字幕天天| 中文字幕热久久久久久久| 欧美777精品久久久久网| 亚洲午夜无码久久久久| 久久人妻少妇嫩草AV无码蜜桃| 精品国产一区二区三区久久久狼| 久久影视综合亚洲| 99久久国产综合精品网成人影院 | 四虎国产精品免费久久久| 一本色道久久综合狠狠躁| 久久精品中文字幕一区| 久久夜色tv网站| 欧美黑人又粗又大久久久| 久久精品中文字幕一区| 综合久久精品色| 日韩中文久久| 色天使久久综合网天天| 三级韩国一区久久二区综合| 久久久久久久亚洲精品| 久久精品无码一区二区三区免费| 久久中文字幕一区二区| 热99re久久国超精品首页| 久久99精品综合国产首页| 国产精品久久久久9999高清| 91视频国产91久久久| 久久不射电影网| 久久国产精品无码网站| 久久夜色精品国产噜噜亚洲a| 亚洲伊人久久成综合人影院 | 国产午夜精品理论片久久影视 |