上手haskell没有不痛苦的!

haskell太怪了,上手很痛苦!

 

module Main where

 

import System.Environment(getArgs)
import qualified Data.ByteString as B (readFile, writeFile, map)

main = do
  args <- getArgs
  case args of
    [from, out, direction] ->
      if direction == "exe2txt"
        then do
          s <- B.readFile from
          let s1 = B.map (/x->x+1) s
          B.writeFile out s1
        else if direction == "txt2exe"
                then do
                  s <- B.readFile from
                  let s1 = B.map (/x->x-1) s
                  B.writeFile out s1
                else do Prelude.putStrLn "usage: hs20101004-1.exe from out direction"
    otherwise ->
      Prelude.putStrLn "usage: hs20101004-1.exe from out direction"

为什么case里面不能case呢?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值