• <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的功能還是挺強(qiáng)大的,簡單的幾十行代碼就搞定了一個小的“數(shù)據(jù)庫”(經(jīng)驗(yàn):調(diào)試macro的時候可以用macroexpand-1展開該macro,看是否與設(shè)想的一樣)。

            感受一下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 閱讀(1009) 評論(0)  編輯 收藏 引用 所屬分類: Lisp
            久久亚洲熟女cc98cm| 欧美精品九九99久久在观看| 久久久91精品国产一区二区三区| 久久精品国产亚洲AV无码偷窥| 2021久久国自产拍精品| 国产成人精品久久免费动漫| 国产精品欧美亚洲韩国日本久久| 久久久久久噜噜精品免费直播| 久久亚洲熟女cc98cm| 91久久婷婷国产综合精品青草 | 91精品国产综合久久久久久| 青青国产成人久久91网| 欧美日韩精品久久久免费观看| 伊人久久综合成人网| 久久精品成人免费看| 一级做a爰片久久毛片看看| 久久精品国产第一区二区三区| 国产精品无码久久久久| 狠狠色丁香婷婷久久综合五月 | 亚洲中文精品久久久久久不卡| 国产午夜精品久久久久免费视| 国产精品无码久久四虎| 亚洲欧美成人综合久久久| 99久久精品无码一区二区毛片| 久久无码专区国产精品发布| 久久精品国产91久久麻豆自制| 欧美成人免费观看久久| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久丫精品国产亚洲av| 精品久久久久久无码国产| 久久青青草原亚洲av无码app| 人妻少妇精品久久| 精品国产乱码久久久久久郑州公司 | 久久精品成人国产午夜| 亚洲精品乱码久久久久久中文字幕| 久久艹国产| 久久国产精品成人片免费| 亚洲国产高清精品线久久 | 午夜福利91久久福利| 久久精品成人免费看| 精品无码久久久久久午夜|