Как разбить строку на подстроки равной длины? - PullRequest
25 голосов
/ 13 сентября 2010

Я ищу элегантный способ в Scala , чтобы разбить данную строку на подстроки фиксированного размера (последняя строка в последовательности может быть короче).

So

split("Thequickbrownfoxjumps", 4)

должно дать

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

Конечно, я мог бы просто использовать цикл, но должно быть более элегантное (функциональный стиль) решение.

Ответы [ 2 ]

62 голосов
/ 13 сентября 2010
scala> val grouped = "Thequickbrownfoxjumps".grouped(4).toList
grouped: List[String] = List(Theq, uick, brow, nfox, jump, s)
1 голос
/ 07 июля 2017

Как это:

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")


\***************************************************************************/
...