我正在尝试解析以下格式的字符串:
(x,y) (r,g,b)
我的文件在每一行上都包含这种字符串。 我已经提取了线条,现在我想提取其值,但是找不到令人满意的东西。 我想做类似的事情:
case str of
['(', x, ',', y, ')', ' ', '(', r, ',', g, ',', b, ')'] -> The rest
我知道它不起作用,我是Haskell的新手,所以我一直遇到我不明白的错误。 我该怎么做?
编辑: 我之前已经创建了它,但是一旦创建了变量,我不知道如何真正使用它:
data Points = Point Coords Colors
data Colors = Color Float Float Float
data Coords = Coord Int Int
数字不限于一位,r,g和b的范围是0到255。
答案 0 :(得分:4)
针对此特定任务的简单技巧:
data Pix = Pix (Int,Int) (Int,Int,Int)
deriving (Read, Show)
parsePix :: ReadS Pix
parsePix s = reads $ "Pix "++s
*Main> parsePix "(1,2) (3,4,5)"
[(Pix (1,2) (3,4,5),"")]
通常,我建议您使用megaparsec。尽管,您应该研究适当的解析器-组合器库。