我现在正在努力学习Lisp,作为我CS1课程的补充,因为课程对我来说太慢了。我选择了“Practical Common Lisp”,到目前为止它已经证明是一本很棒的书,但是我在使用一些例子时遇到了一些麻烦。例如,如果我将以下文件加载到REPL中:
;;;; Created on 2010-09-01 19:44:03
(defun makeCD (title artist rating ripped)
(list :title title :artist artist :rating rating :ripped ripped))
(defvar *db* nil)
(defun addRecord (cd)
(push cd *db*))
(defun dumpDB ()
(dolist (cd *db*)
(format t "~{~a:~10t~a~%~}~%" cd)))
(defun promptRead (prompt)
(format *query-io* "~a: " prompt)
(force-output *query-io*)
(read-line *query-io*))
(defun promptForCD ()
(makeCD
(promptRead "Title")
(promptRead "Artist")
(or (parse-integer (promptRead "Rating") :junk-allowed t) 0)
(y-or-n-p "Ripped [y/n]: ")))
(defun addCDs ()
(loop (addRecord (promptForCD))
(if (not (y-or-n-p "Another? [y/n]: ")) (return))))
(defun saveDB (fileName)
(with-open-file (out fileName
:direction :output
:if-exists :supersede)
(with-standard-io-syntax
(print *db* out))))
(defun loadDB (fileName)
(with-open-file (in fileName)
(with-standard-io-syntax
(setf *db* (read in)))))
(defun select (selectorFn)
(remove-if-not selectorFn *db*))
(defun artistSelector (artist)
#'(lambda (cd) (equal (getf cd :artist) artist)))
使用(select (artistSelector "The Beatles"))
查询'数据库',即使我确实在:artist
等于"The Beatles"
的数据库中有一个条目,该函数返回NIL
我在这里做错了什么?
答案 0 :(得分:4)
没什么,AFAICT:
$ sbcl This is SBCL 1.0.34.0... [[pasted in code above verbatim, then:]] * (addRecord (makeCD "White Album" "The Beatles" 5 t)) ((:TITLE "White Album" :ARTIST "The Beatles" :RATING 5 :RIPPED T)) * (select (artistSelector "The Beatles")) ((:TITLE "White Album" :ARTIST "The Beatles" :RATING 5 :RIPPED T))
答案 1 :(得分:1)
CL-USER 18 > (addcds)
Title: Black Album
Artist: Prince
Rating: 10
Title: White Album
Artist: The Beatles
Rating: 10
NIL
CL-USER 19 > (select (artistSelector "The Beatles"))
((:TITLE "White Album" :ARTIST "The Beatles" :RATING 10 :RIPPED T))