Например, у меня есть список строк, таких как:
val list = listOf("a", "b", "c", "d")
и я хочу преобразовать его в карту, где строки являются ключами.
Я знаю, что должен использовать .toMap()
, но я не знаю как, и я не видел ни одного примера.
Например, у меня есть список строк, таких как:
val list = listOf("a", "b", "c", "d")
и я хочу преобразовать его в карту, где строки являются ключами.
Я знаю, что должен использовать .toMap()
, но я не знаю как, и я не видел ни одного примера.
У вас есть два варианта:
Первым и наиболее эффективным является использование функции associateBy
, которая принимает два lambdas для генерации ключа и значения и строит создание карты:
val map = friends.associateBy({it.facebookId}, {it.points})
Вторая, менее эффективная, заключается в использовании стандартной функции map
для создания списка Pair
, который может использоваться toMap
для создания окончательной карты:
val map = friends.map { it.facebookId to it.points }.toMap()
List
до Map
с функцией associate
В Kotlin 1.3 функция List
имеет функцию associate
. associate
имеет следующую декларацию:
fun <T, K, V> Iterable<T>.associate(transform: (T) -> Pair<K, V>): Map<K, V>
Возвращает
Map
, содержащий пары ключ-значение, предоставляемые функциейtransform
, примененной к элементам данной коллекции.
Использование:
class Person(val name: String, val id: Int)
fun main() {
val friends = listOf(Person("Sue Helen", 1), Person("JR", 2), Person("Pamela", 3))
val map = friends.associate({ Pair(it.id, it.name) })
//val map = friends.associate({ it.id to it.name }) // also works
println(map) // prints: {1=Sue Helen, 2=JR, 3=Pamela}
}
List
до Map
с функцией associateBy
В Kotlin функция List
имеет функцию associateBy
. associateBy
имеет следующую декларацию:
fun <T, K, V> Iterable<T>.associateBy(keySelector: (T) -> K, valueTransform: (T) -> V): Map<K, V>
Возвращает
Map
, содержащий значения, предоставленныеvalueTransform
и проиндексированные функциямиkeySelector
, примененные к элементам данной коллекции.
Использование:
class Person(val name: String, val id: Int)
fun main() {
val friends = listOf(Person("Sue Helen", 1), Person("JR", 2), Person("Pamela", 3))
val map = friends.associateBy(keySelector = { person -> person.id }, valueTransform = { person -> person.name })
//val map = friends.associateBy({ it.id }, { it.name }) // also works
println(map) // prints: {1=Sue Helen, 2=JR, 3=Pamela}
}
Вы можете использовать associate
для этой задачи:
val list = listOf("a", "b", "c", "d")
val m: Map<String, Int> = list.associate { it to it.length }
В этом примере строки из list
становятся ключами, а их соответствующие длины (в качестве примера) становятся значениями внутри карты.
* Ссылка:Документация Kotlin
1- Associate (для установки обоих ключей и значений): создайте карту, в которой можно установить ключи и значения; элементы значения:
IterableSequenceElements.associate { newKey to newValue } //Output => Map {newKey : newValue ,...}
Если какая-либо из двух пар будет иметь одинаковый ключ, последняя добавляется на карту.
Возвращенная карта сохраняет порядок итераций входа исходного массива.
2- associateBy (просто установите ключи по расчету): создайте карту, в которой мы можем установить новые ключи, аналогичные элементы будут установлены для значений
IterableSequenceElements.associateBy { newKey } //Result: => Map {newKey : 'Values will be set from analogous IterableSequenceElements' ,...}
3- associateWith (просто установите значения по расчету): создайте карту, в которой мы можем установить новые значения, аналогичные элементы будут установлены для ключей
IterableSequenceElements.associateWith { newValue } //Result => Map { 'Keys will be set from analogous IterableSequenceElements' : newValue , ...}
Новый Kotlin настолько прост, проверьте это:
val via=listOf("a" to 1,"b" to 2, "c" to 3).toMap()
print out -> {a=1, b=2, c=3}
или для индекса используйте ассоциацию:
val sim:String= "simple"
val map= sim.associate({it to sim.indexOf(it)})
print out -> {s=0, c=1, o=2, t=3, l=4, a=5, n=6, d=7}
Это изменилось в версии RC.
Я использую val map = list.groupByTo(destinationMap, {it.facebookId}, { it -> it.point })
Если в вашем списке есть дубликаты, которые вы не хотите терять, вы можете сделать это с помощью groupBy
.
В противном случае, как и все остальные, используйте associate/By/With
(который, как я полагаю, в случае дубликатов будет возвращать только последнее значение с этим ключом).
Пример группировки списка людей по возрасту:
class Person(val name: String, val age: Int)
fun main() {
val people = listOf(Person("Sue Helen", 31), Person("JR", 25), Person("Pamela", 31))
val duplicatesKept = people.groupBy { it.age }
val duplicatesLost = people.associateBy({ it.age }, { it })
println(duplicatesKept)
println(duplicatesLost)
}
Результаты:
{31=[[email protected], [email protected]], 25=[[email protected]]}
{[email protected], [email protected]}
Например, у вас есть список строк, таких как:
val list = listOf("a", "b", "c", "d")
и вам нужно преобразовать его в карту, где строки являются ключами.
Есть два способа сделать это:
Первым и наиболее эффективным является использование функции associateBy, которая принимает две лямбда-выражения для генерации ключа и значения и указывает на создание карты:
val map = friends.associateBy({it.facebookId}, {it.points})
Второй, менее производительный, заключается в использовании стандартной функции карты для создания списка Pair, который может использоваться toMap для генерации окончательной карты:
val map = friends.map { it.facebookId to it.points }.toMap()