2016-12-06 2 views
0

Я пытаюсь получить список значений из подструктуры. я следующая структураПолучить список значений из подписок с Control.Lens

("Value",[(1,"1"),(2,"2"),(3,"3"),(4,"4"),(5,"5")]) 

И я пытаюсь получить второй элемент кортежей из списка.

[ "1", "2", "3", "4", "5"]

Выражение Я связывая это

вид (_2. ToListOf. _2) а

Я также пробовал траверс. Но похоже, что траверс имеет складной эффект в списке. Мне нужен результат в виде списка.

Prelude Control.Lens> let a = ("Value", [(i, show i)|i<-[1..5]]) :: (String, [(Int, String)]) 
Prelude Control.Lens> a 
("Value",[(1,"1"),(2,"2"),(3,"3"),(4,"4"),(5,"5")]) 
Prelude Control.Lens> view (_2 . toListOf . _2) a 

<interactive>:36:7: error: 
    • Couldn't match type ‘[]’ with ‘Const t’ 
     Expected type: Getting t (String, [(Int, String)]) t 
     Actual type: (t -> Const t t) 
        -> (String, [(Int, String)]) -> [(String, [(Int, String)])] 
    • In the first argument of ‘view’, namely ‘(_2 . toListOf . _2)’ 
     In the expression: view (_2 . toListOf . _2) a 
     In an equation for ‘it’: it = view (_2 . toListOf . _2) a 
    • Relevant bindings include it :: t (bound at <interactive>:36:1) 

<interactive>:36:23: error: 
    • Couldn't match type ‘Const t t0’ 
        with ‘[(Int, String)] 
          -> Const (Data.Monoid.Endo [[(Int, String)]]) [(Int, String)]’ 
     Expected type: (t -> Const t t) 
        -> Getting 
          (Data.Monoid.Endo [[(Int, String)]]) 
          [(Int, String)] 
          [(Int, String)] 
     Actual type: (t -> Const t t) 
        -> ([(Int, String)] 
         -> Const (Data.Monoid.Endo [[(Int, String)]]) [(Int, String)]) 
        -> Const t t0 
    • In the second argument of ‘(.)’, namely ‘_2’ 
     In the second argument of ‘(.)’, namely ‘toListOf . _2’ 
     In the first argument of ‘view’, namely ‘(_2 . toListOf . _2)’ 
    • Relevant bindings include it :: t (bound at <interactive>:36:1) 
Prelude Control.Lens> 

ответ

2

В документации сказано:

Посмотреть значение указывает получателе Iso или объектива или в результате складывания по всем результатам Fold или Traversal, что указывает на моноидальном значение.

toListOf вместо view. Например:

toListOf (_2.traverse._2) a 

Или

a ^.. _2 . traverse . _2 

Так, toListOf не объектив, это просто еще один оператор, как view, но он извлекает список целей в вислоухая.

+0

Работал как очарование. Спасибо. – yilmazhuseyin

Смежные вопросы