f# - FParsec react 示例

标签 f# system.reactive parser-combinators fparsec

我希望有人可以发布一个使用 FParsec 的示例,其中数据基于某种传入的实时流。

一些示例可能是根据鼠标手势生成结果,根据特定的股票报价序列生成警报或通知。

如果有人可以发布示例,将不胜感激。

谢谢!

最佳答案

您正在寻找的是 Reactive Parsers从 Rxx 中取出。

这不是 F#,而是一个 .NET 库,可让您编写如下代码(根据您的常用示例):

    var alerts = ticks.Parse(parser =>
    from next in parser
    let ups = next.Where(tick => tick.Change > 0)
    let downs = next.Where(tick => tick.Change < 0)
    let downAlert = from manyUps in ups.AtLeast(2).ToList()
               from reversalDown in downs.NonGreedy()
               where reversalDown.Change <= -11
               select new StockAlert(manyUps, reversalDown)
    let upAlert = from manyDowns in downs.AtLeast(2).ToList()
            from reversalUp in ups.NonGreedy()
            where reversalUp.Change >= 21
            select new StockAlert(manyDowns, reversalUp)
    select downAlert.Or(upAlert).Ambiguous(untilCount: 1));

当然要归功于 Dave Sexton 和 James Miles,他们完成了大部分工作。

对于背景阅读,Rxx 的解析器扩展来自这个讨论:http://qa.social.msdn.microsoft.com/Forums/eu/rx/thread/0f72e5c0-1476-4969-92da-633000346d0d

这是一个非常简单的示例,说明如何在 F# 中使用它:

open Rxx.Parsers.Reactive
open Rxx.Parsers.Reactive.Linq

// F# shortcuts to Rxx
let where f (a:IObservableParser<_,_>) = a.Where(fun b -> f b)
let toList (parser:IObservableParser<_,_>) = parser.ToList()
let (<&>) (a:IObservableParser<'a,'b>) (b:IObservableParser<'a,'b>) = a.And(b)
let create a = 
    { new ObservableParser<_,_>() with
        override x.Start = a(x.Next) } :> IObservableParser<_,_>
let parse (parser:IObservableParser<_,_>) (obs:IObservable<_>) = obs.Parse(parser)

// example of grammar
let grammar = 
    (fun (parser:IObservableParser<_,_>) ->
        let next = parser.Next
        let bigs = next |> where(fun i -> i > 25)
        let smalls = next |> where(fun i -> i <= 25)
        bigs <&> smalls |> toList ) 
    |> create

// the test
let random = Random()
let values = Observable.Interval(TimeSpan.FromMilliseconds(500.0)).Select( fun _ -> random.Next(1,50)).Trace().TraceSubscriptions("subbing","subbed","disposing","disposed").Publish()

let sub = values |> parse grammar |> Observable.add(printfn "BIG THEN SMALL: %A")
let test = values.Connect()

关于f# - FParsec react 示例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9913065/

相关文章:

Scala 解析器组合器 : Efficiently Parse C-Style Comments

parsing - Scala组合器解析器,>>是什么意思?

f# - 如何在 F# 中一般处理选项值

c# - 响应式(Reactive) ("Rx") 缓存和更新数据的方式

android - 编写多个网络调用 RxJava - Android

c# - 如何在特定时间启动 IObservable?

haskell - 递归到 Haskell 中尚不存在的函数

f# - 在F#的此示例中避免突变

f# - “not equal to”的F#语法是什么?

f# - FSharp 参数模式匹配。为什么声明分配自而不是分配给?