Как разбить строку на подстроки равной длины?
Я ищу элегантный способ в Scala разбить данную строку на подстроки фиксированного размера (последняя строка в последовательности может быть короче).
Так
split("Thequickbrownfoxjumps", 4)
должен уступить
["Theq","uick","brow","nfox","jump","s"]
Конечно, я мог бы просто использовать цикл, но должно быть более элегантное (функциональный стиль) решение.
2 ответа
Решение
scala> val grouped = "Thequickbrownfoxjumps".grouped(4).toList
grouped: List[String] = List(Theq, uick, brow, nfox, jump, s)
Как это:
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")
\***************************************************************************/