별의 공부 블로그 🧑🏻‍💻
728x90
728x170
;; INPUT/OUTPUT

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; WITH-OPEN-FILE ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Opening file for output ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

(defun get-tree-data ()
(with-open-file (stream "timber.txt")
(let* ((tree-loc (read stream))
(tree-table (read stream))
(num-trees (read stream)))
(format t "~&There are ~S trees on ~S." num-trees tree-loc)
(format t "~&They are: ~S" tree-table))))


;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; WITH-OPEN-FILE ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Opening file for output ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

(defun save-tree-data (tree-loc tree-table num-trees)
(with-open-file (stream "timber.txt"
:direction :io
:if-exists :overwrite
:if-does-not-exist :create)
(format stream "~&~S~%" tree-loc)
(format stream "~&~S~%" tree-table)
(format stream "~&~S~%" num-trees)))

;; The text file is made in this location : C:\acl100express (Initial Location)
;; > (save-tree-data "The West Ridge"
;; '((45 redwood) (22 oak) (43 maple))
;; 110)

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

;; Change the location to save the file?
(defun save-tree-data2 (tree-loc tree-table num-trees)
(with-open-file (stream "c:/temp/timber.txt" ;; You should use '/' instead of '\'. (UNIX System)
:direction :io
:if-exists :overwrite
:if-does-not-exist :create)
(format stream "~&~S~%" tree-loc)
(format stream "~&~S~%" tree-table)
(format stream "~&~S~%" num-trees)))

;; > (save-tree-data2 "The West Ridge"
;; '((45 redwood) (22 oak) (43 maple))
;; 110)



;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Handling End Of File ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(defun read-my-file()
(with-open-file (stream "sample.txt")
(let ((contents (read-all-objects stream)))
(format t "~&Read ~3D objects from the file."
(length contents))
(contents))))

(defun read-all-objects (stream &optional eof-indicator)
(let ((result (read stream nil eof-indicator)))
(if (eq result eof-indicator) ;; same address?
nil
(cons result (read-all-objects stream)))))


728x90
그리드형(광고전용)

'Source Code > LISP (CL)' 카테고리의 다른 글

Block's World  (0) 2017.06.08
samesetp  (0) 2017.05.31
Tic Tac Toe Game  (0) 2017.05.30
순환 (Recursion)  (0) 2017.05.16
Checking whether an input element is a number or not with using DO macro. (Infinite Loop)  (0) 2017.04.21
⚠️AdBlock이 감지되었습니다. 원할한 페이지 표시를 위해 AdBlock을 꺼주세요.⚠️


📖 Contents 📖