首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将错误处理添加到列表单?我需要什么数据类型?

如何将错误处理添加到列表单?我需要什么数据类型?
EN

Stack Overflow用户
提问于 2016-09-22 21:17:05
回答 1查看 102关注 0票数 2
代码语言:javascript
复制
let test2 =
        (fromDocument (doc :: Document) $/ element "body")
        >>= ($/ element "div")
        >>= (attributeIs "id" "content")
        >>= ($/ element "div")
        >>= (attributeIs "class" "box")

我使用的是xml-conduit库,我得到了上面的代码,它实际上过滤了一棵树(一棵XML )。

如果任何绑定(>>=) (如果正确的话)返回一个空列表,我想将功能添加到"error“中。

我想做的事:

elementattributeIs都返回Axis,即Cursor -> [Cursor]

我发现很难确定我需要使用的数据类型。我正在考虑使用Either来返回Left a (a将是一个类似于attributeIs "id" "content"的函数)或Right Axis

但是,如果我的理解是正确的,我就无法返回列表中的Either类型。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-09-23 11:30:28

如果它用于快速调试,只需使用Debug.Trace即可。否则,您将请求合并monads、ListEither String:这是一个monad变压器。考虑下面这个关于整数而不是XML树的简单示例:

代码语言:javascript
复制
plusOne :: Int -> [Int]
plusOne x = [x+1]

void :: Int -> [Int]
void x = if x <= 2 then [x] else []

listPipe :: [Int]
listPipe = [1,2,3] >>= plusOne >>= void

listPipe中的一些值是由void裁剪的,您想知道这在运行时何时发生。然后你的类型变成:

代码语言:javascript
复制
plusOne :: Int -> Either String [Int]
void :: Int -> Either String [Int]
listPipe :: Either String [Int]

它与ListT (Either String) Int类型同构。包装给你的是:

代码语言:javascript
复制
import Control.Monad.Trans.List

void :: Int -> ListT (Either String) Int
void x = ListT $ if x <= 2 then Right [x] else Left "errorVoid"

plusOne :: Int -> ListT (Either String) Int
plusOne x = ListT $ Right [x+1]

listPipe :: Either String [Int]
listPipe = runListT $ ListT (Right [1,2,3]) >>= plusOne >>= void

listPipe = Left "errorVoid"

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39649028

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档