大多数Clojure库不仅提供了在project.clj文件中放置什么的信息,而且还提供了如何在源文件中require库的信息。例如,https://github.com/clojure/data.json提供了一个使用部分:
(ns example
(:require [clojure.data.json :as json]))我想使用Clojars库(它是一个Java库),它列在Clojars:https://clojars.org/zololabs/jericho-html-parser上。我已经成功地将这个依赖项添加到我的project.clj文件中,但是我不知道如何将它添加到require文件中。
我尝试过(require '[zololabs.jericho-html-parser])和许多变体,但似乎都没有效果。我已经查看了库的命名约定,我知道如何确定是否能够识别这种模式,但我没有成功。
根据文件名、莱宁根坐标或其他信息,有一种简单的方法可以告诉您如何使用require库吗?
发布于 2015-08-28 23:12:03
首先,您不需要从require中获取一个Java库,而是import一个或多个Java类。例如:
(:import [net.htmlparser.jericho Source TextExtractor])然后通过Java互操作使用这些类。例如:
(Source. (java.net.URL. "https://yahoo.com"))请注意,您不需要导入已经在类路径中的Java类才能使用它们。您可以避免导入,如果要使用它们一次或两次,只需使用它们完全限定的名称:
(net.htmlparser.jericho.Source. (java.net.URL. "https://www.yahoo.com"))显然,您需要首先查找Java库API并了解它是如何工作的。在本例中,请参见这里。
发布于 2015-08-28 22:28:12
你刚刚发现了克洛尔的一个破产案。
简单地说,您缺少了一个冒号,这是源文件中使用的(ns ...)表单所必需的:
(ns example
(:require [clojure.data.json :as json]))注意,由于ns是一个宏,源文件版本在左方括号之前不需要单引号。
另一种情况是在REPL中使用(require ...)函数。在这种情况下,您需要语法:
> (require '[clojure.data.json :as json])其中,>是REPL提示符。在本例中,您正在调用一个函数,因此在require之前没有冒号。但是,由于函数不是宏,因此需要引用指定库名及其别名的向量。
https://stackoverflow.com/questions/32279991
复制相似问题