• <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
            中文字幕久久精品无码| 精品久久无码中文字幕| 久久综合久久鬼色| 99久久精品免费看国产一区二区三区| 久久婷婷五月综合97色| 国产成人精品久久亚洲高清不卡 | 亚洲国产精品久久久久网站 | 久久综合九色综合欧美就去吻| 久久www免费人成看国产片| 久久久久久伊人高潮影院| 久久九九亚洲精品| 久久精品国产日本波多野结衣| 99久久精品国产免看国产一区| 精品综合久久久久久88小说| 亚洲中文字幕无码久久综合网 | 国产激情久久久久影院小草 | 成人a毛片久久免费播放| 亚洲色欲久久久久综合网| 久久91综合国产91久久精品| 99精品国产免费久久久久久下载| 97精品国产91久久久久久| 亚洲美日韩Av中文字幕无码久久久妻妇 | 久久无码av三级| 影音先锋女人AV鲁色资源网久久| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久九色综合九色99伊人| 99麻豆久久久国产精品免费| 久久综合给合综合久久| 久久婷婷国产麻豆91天堂| 久久精品aⅴ无码中文字字幕不卡| 亚洲欧美国产精品专区久久| 久久精品亚洲男人的天堂| 国产成人久久777777| 久久这里只有精品久久| 精品久久久久久亚洲精品| 久久亚洲美女精品国产精品| 久久99久国产麻精品66| 久久香综合精品久久伊人| 99蜜桃臀久久久欧美精品网站| 精品熟女少妇AV免费久久| 亚洲国产精品成人久久|