繁体   English   中英

如何在 Haskell 中将构造函数转换为字符串?

[英]How to convert from a constructor to a string in Haskell?

我正在尝试 output 一手字符串格式的卡片,但我不能从卡片的等级中删除“数字”这个词,我宁愿在没有助手 function 的情况下这样做,因为它看起来真的很乱,任何建议在没有助手 function 的情况下执行此操作。 另外,当我使用display function 时,我在 Prelude 中使用putStr (display x) 这是到目前为止的代码:

displayCard :: Card -> String
displayCard c = show (rank c) ++ " of " ++ show (suit c) ++ "\n"

display :: Hand -> String
display Empty = "\n"
display (Add c h) = displayCard c
                    ++ display h

displayRank :: Rank -> String
displayRank (Numeric 2) = "2"
displayRank (Numeric 3) = "3"
displayRank (Numeric 4) = "4"
displayRank (Numeric 5) = "5"
displayRank (Numeric 6) = "6"
displayRank (Numeric 7) = "7"
displayRank (Numeric 8) = "8"
displayRank (Numeric 9) = "9"
displayRank (Numeric 10) = "10"
displayRank Jack = "Jack"
displayRank Queen = "Queen"
displayRank King = "King"
displayRank Ace = "Ace"

我宁愿在没有助手 function 的情况下这样做,因为它看起来真的很乱

假设您有以下类型,

data Card = Card { cardRank :: Rank, cardSuit :: Suit }
  deriving (Eq, Show)

data Rank = Numeric Int | Jack | Queen | King | Ace
  deriving (Eq, Show)

data Suit = Diamonds | Clubs | Hearts | Spades
  deriving (Eq, Show)

那么编写辅助函数就有意义了

displayRank :: Rank -> String
displayRank (Numeric n) = show n
displayRank otherRank = show otherRank

displaySuit :: Suit -> String
displaySuit = show

displayCard :: Card -> String
displayCard (Card rank suit) = ...

但您也可以将它们组合起来:

displayCard :: Card -> String
displayCard (Card (Numeric n) suit) = ...
displayCard (Card otherRank suit) = ...

拥有正确设计的辅助函数并不混乱。 相反。

你用show (rank c)完成了什么,

rank ::        Card -> Rank
show ::                Rank -> String

您可以使用displayRank (rank c)完成

rank ::        Card -> Rank
displayRank ::         Rank -> String

(说到类型)。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM