вы можете перебирать данные и применять к шаблону, используя String.replace
, и продолжать перебирать новое состояние.
Учитывая,
scala> val template = "{placeholder1}/{placeholder2}-{placeholder3}/{placeholder4}.{placeholder5}"
template: String = {placeholder1}/{placeholder2}-{placeholder3}/{placeholder4}.{placeholder5}
scala> val data = Map("placeholder1" -> "aaa",
"placeholder2" -> "xxx",
"placeholder3" -> "yyy",
"placeholder4" -> "zzz",
"placeholder5" -> "bbb")
data: scala.collection.immutable.Map[String,String] = HashMap(placeholder5 -> bbb, placeholder1 -> aaa, placeholder3 -> yyy, placeholder2 -> xxx, placeholder4 -> zzz)
применятьшаблон данных с использованием foldLeft
.Я предполагаю, что {}
обозначает заполнитель шаблона.
scala> data.foldLeft(template){ case (newState, kv) => newState.replace(s"{${kv._1}}", kv._2)}
res6: String = aaa/xxx-yyy/zzz.bbb
ПРИМЕЧАНИЕ: kv
выше - это каждая запись в Map
, в качестве альтернативы вы можете деконструировать kv
как(k, v)
.
scala> data.foldLeft(template){ case (newState, (k, v)) => newState.replace(s"{$k}", v)}
res7: String = aaa/xxx-yyy/zzz.bbb
Альтернативное решение :
Хотя .foldLeft
достаточно, вы можете написать свою собственную ванильную рекурсивную систему, которая применимапо одной записи за раз и продолжает повторяться до тех пор, пока данные не станут пустыми.
def format(template: String, data: Map[String, String]): String = {
if(data.isEmpty) template
else format(template.replace(s"{${data.head._1}}", data.head._2), data.tail)
}
val formatted = format(template, data) // aaa/xxx-yyy/zzz.bbb