- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
对于一项任务,我们必须实现类似非常基本的 sexp 解析器的东西,这样的输入如下:
"((a b) ((c d) e) f)"
它会返回:
[["a", "b"], [["c", "d"], "e"], "f"]
因为这是一个更大的任务的一部分,解析器只得到有效的输入(匹配的括号&c)。我在 Ruby 中想出了以下解决方案:
def parse s, start, stop
tokens = s.scan(/#{Regexp.escape(start)}|#{Regexp.escape(stop)}|\w+/)
stack = [[]]
tokens.each do |tok|
case tok
when start
stack << []
when stop
stack[-2] << stack.pop
else
stack[-1] << tok
end
end
return stack[-1][-1]
end
这可能不是最好的解决方案,但它可以完成工作。
现在,我对核心功能的惯用 Haskell 解决方案感兴趣(即我不关心词法分析或定界符的选择,采用已经词法分析的输入就可以了),如果可能的话只使用“核心”haskell ,没有像 parsec 这样的扩展或库。
请注意,这不是作业的一部分,我只是对 Haskell 的做事方式感兴趣。
最佳答案
[["a", "b"], [["c", "d"], "e"], "f"]
在 haskell 中没有有效类型(因为在 haskell 中列表的所有元素都必须是同一类型),因此您需要为嵌套列表定义自己的数据结构,如下所示:
data NestedList = Value String | Nesting [NestedList]
现在,如果您有一个 Token 列表,其中 Token 被定义为 data Token = LPar |帕尔 | Symbol String
,你可以像这样将其解析为 NestedList:
parse = fst . parse'
parse' (LPar : tokens) =
let (inner, rest) = parse' tokens
(next, outer) = parse' rest
in
(Nesting inner : next, outer)
parse' (RPar : tokens) = ([], tokens)
parse' ((Symbol str) : tokens) =
let (next, outer) = parse' tokens in
(Value str : next, outer)
parse' [] = ([],[])
关于ruby - 非常简单的 sexp 解析器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3128406/
我有很棒的vim-sexp和 vim-sexp-mappings-for-regular-people安装了插件,我遇到了一个我不确定如何解决的情况。 假设我有以下形式: (alimony barba
在任何 lisp 中是否有一种形式可以“传播”父 sexp 中的列表?喜欢: (+ (spread '(1 2 3))) -> (+ 1 2 3) 最佳答案 有两种方法可以做到这一点。哪个更好取决于你
如果我写一个文件使用 (with-open-file (s "~/example.sexp" :direction :output) (write '(1 2 3) :strea
我正在尝试创建一个捕获模板,该模板将 URL 转换为带有 的组织模式链接。作为链接名称。 我的转换函数如下所示: (defun get-page-title (url) "Get title o
sexp 是这样的:type sexp = Atom of string | sexp 列表列表,例如,"((a b) ((c d) e) f)"。 我编写了一个解析器来将 sexp 字符串解析为以下
我正在使用 C 中的 R 内部接口(interface)。我需要从 C 中分析 SEXP 的内容,但我不知道确切的 SEXP 结构。有没有一种简单的方法(或一些现有代码)可以将 SEXP 转储到控制台
我正在写一个 R package to provide debug helper functions gdb 打印 R 的 SEXP 和 Rcpp 数据类型的变量值。 C/C++ 是一种强类型语言,但
我有一个函数可以替换列表中符号的所有实例: (defun replace-symbol-in-sexp-fn (symbol-to-replace new-symbol sexp) (if (eq
对于一项任务,我们必须实现类似非常基本的 sexp 解析器的东西,这样的输入如下: "((a b) ((c d) e) f)" 它会返回: [["a", "b"], [["c", "d"], "e"]
这个问题在这里已经有了答案: Initialize a variable with different type based on a switch statement (2 个答案) 关闭 6 年
如何使用 org-contacts 设置纪念日,以便在我的议程.org 文件中显示生日等内容? 我的议程.org 文件包含以下内容,如 org-contacts 底部所述 #+STARTUP: sho
我需要将已知长度的 const char* 转换为 Rcpp::RawVector 以返回到 R. Rcpp::wrap 适用于许多类型,但似乎不适用于 char *。 最佳答案 library(Rc
愚蠢的人,但我自己想不出来 - 我如何获得下一个 sexp?就像 preceding-sexp 一样,但是向前。 最佳答案 查看 forward-sexp。你有一个很好的例子here . 好的,根据您
我在 utop 中运行这段代码: # type u = { a: int; b: float } [@@deriving sexp];; 但是没有生成预期的 s 表达式转换器声明。 我安装了 Core
我在 Hadley Wickham 的书中读到 RObjects 应该在 R 的 C API 中声明为 S 表达式 (SEXP): SEXP x( SEXP a, SEXP b { } 然而,在 Rc
假设我有一个函数将 SEXP 类型作为参数: SEXP myFun(SEXP param) 如何找出这个参数的类型?查看我的调试器中的 SEXP 类型,我可以看到我可以调用 param->sxpinf
考虑一个虚拟的例子 > cppFunction(' + NumericVector invert(NumericVector& x) { + x = x + 1; + return x
SEXP callFunction1(List network, List words, Function testWordContinuity){ SEXP res = testWordCont
有没有办法转换 arma::subview进入 SEXP ?创建矩阵后我有以下代码 X在我的 Rcpp代码: //.... MCMC loop if(i % skiplength == 0)
正在关注 this recipe ,我准备了这个搜索命令: (shell-command "grep . /tmp/listoffiles | xargs grep -n mystring" 1) 如
我是一名优秀的程序员,十分优秀!