没有一个库函数可以将十六进制数字转换为二进制字符串。您可以使用模块 Numeric 中的 readHex 将十六进制数字转换为整数,并使用 Text.Printf 模块中的 printf 生成二进制字符串,如下所示:
import Numeric (readHex)
import Text.Printf (printf)
hexToBin :: Char -> Maybe String
hexToBin c
= case readHex [c] of
(x,_):_ -> Just $ printf "%04b" (x::Int)
_ -> Nothing
给予:
> map hexToBin (['0'..'9'] ++ ['A'..'G'])
[Just "0000",Just "0001",Just "0010",Just "0011",Just "0100",
Just "0101",Just "0110",Just "0111",Just "1000",Just "1001",
Just "1010",Just "1011",Just "1100",Just "1101",Just "1110",
Just "1111",Nothing]