2024年Clojure状态调查!中分享您的想法。

欢迎!请参见关于页面获取更多有关此操作的信息。

0 投票
名称空间和变量
已关闭

所以...简要来说,这是我的core.clj文件

(ns ffmpeg-in-a-jar.core
  (:gen-class)
  (:require [ffmpeg-in-a-jar.encoder :as encoder]))

(defn -main
  "ffmpeg autoencoder made with Clojure"
  [& args]
  (println "Files will begin encoding..." ))

在encoder.clj文件中,我定义了一个用户自定义的循环计数器

(defn loop-cnt []
  (println "How many files to encode?")
  (def loopnum (read-string (read-line)))
  (println "\n""Files ready to encode"))

(loop-cnt)

它就在循环中使用后,再次请求用户输入

(defn queue []
  (loop [loopnum loopnum
         file-queue []]
   (if (not= loopnum 0)
     (do
       (def file-queue [])
       (println "\n""Write filenames one by one")
       (def add-queue (read-line))
       (recur (dec loopnum) (conj file-queue add-queue)))
     file-queue)))

我使用以下方式调用这些(代码已省略)

(loop-cnt)
(def queue-result (queue))
(println "\n""Added to the Encoding Queue:" "\n" queue-result "\n")

我的真正疑惑是,encoder是如何工作的,我用require使其可用,但我还没有在-iostate中调用它,我以为应该是这样

(encoder/loop-cnt)
(println "\n" "Added to the Encoding Queue:" "\n" encoder/queue-result "\n")

ns宏是否在做一些我不清楚的事情?

已关闭,注释为: 已解决。愚蠢的错误

1 个答案

0 投票

我刚到家,重新检查了代码,似乎我重复调用了函数。忘记了在encoder.clj文件中的文件内测试(它们通过require运行了一次,然后通过-iostate再次运行)。

Oops :)

新的core.clj现在按照预期工作了。

(ns ffmpeg_in_a_jar.core
  (:gen-class)
  (:require [ffmpeg_in_a_jar.encoder :as encoder]))

(defn -main
  "ffmpeg autoencoder made with Clojure"
  [& args]
  (encoder/loop-cnt)
  (def queue-result (encoder/queue))
  (println "\n" "Added to the Encoding Queue:" "\n" queue-result "\n")
  (println "Files will begin encoding..." ))
仅提醒一下,`def` 会创建全局变量,通常只应在顶层使用。这里你应该使用 `let` 来为 queue-result 创建局部绑定,但相同的情况也适用于你之前的 loop-num、file-queue、add-queue 等。
...