2010-09-13 153 views
22

我正在寻找优雅方式Scala将给定的字符串拆分为固定大小的子字符串(序列中的最后一个字符串可能更短)。如何将字符串拆分为等长的子字符串?

所以

split("Thequickbrownfoxjumps", 4) 

应该产生

["Theq","uick","brow","nfox","jump","s"] 

当然,我可以简单地用一个循环,但必须有一个更优雅(功能型)解决方案。

回答

55
scala> val grouped = "Thequickbrownfoxjumps".grouped(4).toList 
grouped: List[String] = List(Theq, uick, brow, nfox, jump, s) 
1

像这样:

def splitString(xs: String, n: Int): List[String] = { 
    if (xs.isEmpty) Nil 
    else { 
    val (ys, zs) = xs.splitAt(n) 
    ys :: splitString(zs, n) 
    } 
} 

splitString("Thequickbrownfoxjumps", 4) 
/************************************Executing-Process**********************************\ 
( ys  ,  zs   ) 
    Theq  uickbrownfoxjumps 
    uick  brownfoxjumps 
    brow  nfoxjumps 
    nfox  jumps 
    jump  s 
    s   ""     ("".isEmpty // true) 


"" :: Nil     ==> List("s") 
"jump" :: List("s")   ==> List("jump", "s") 
"nfox" :: List("jump", "s") ==> List("nfox", "jump", "s") 
"brow" :: List("nfox", "jump", "s") ==> List("brow", "nfox", "jump", "s") 
"uick" :: List("brow", "nfox", "jump", "s") ==> List("uick", "brow", "nfox", "jump", "s") 
"Theq" :: List("uick", "brow", "nfox", "jump", "s") ==> List("Theq", "uick", "brow", "nfox", "jump", "s") 


\***************************************************************************/ 
相关问题