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来使其可用,但我在 داخل -main 中还没有调用它,我想应该是

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

ns宏做了我不知道的事情吗?

以以下备注关闭: 已解决。愚蠢的错误

1 答案

0

我刚到家,重新检查了代码,看起来我重复调用了一些函数。忘记了在encoder.clj(通过require运行一次,然后通过 -main 再次运行)中的in-file测试取消注释

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 等也是一样。
...