Котлин; группировать по нескольким полям - PullRequest
1 голос
/ 07 марта 2019

Как я могу сделать groupBy в своем коде тремя или более полями?Мой код, как показано ниже:

val nozzleSaleReport = nozzleStateList.groupBy {
                {it.shift.id},{it.createUser.id},{it.nozzle.id} // Here I need to add these three fields for grouping operation
            }.map { entry ->
                val max: Float = (entry.value.maxBy { it.nozzleState.finalLitreMechanical }?.nozzleState!!.finalLitreMechanical ?: 0).toString().toFloat()
                val min: Float = (entry.value.minBy { it.nozzleState.finalLitreMechanical }?.nozzleState!!.finalLitreMechanical ?: 0).toString().toFloat()

                NozzleSaleReport(entry.value[0].createUser.name, entry.value[0].shift.name,  (max - min).toInt(),entry.value[0].shift.id, entry.value[0].nozzle.id, entry.value[0].nozzle.name)
            }.let {
                println(it) 
            }

1 Ответ

2 голосов
/ 07 марта 2019

Допустим, класс элементов вашей коллекции равен NozzleState.

Вы хотите сгруппировать состояния сопел по идентификатору сдвига, создать идентификатор пользователя и идентификатор сопла.

Если я правильно понимаю, вам нужна отдельная группа для каждой отдельной комбинации идентификатора смены, создания идентификатора пользователя и идентификатора сопла.

Таким образом, вам нужно создать класс, представляющий такую ​​комбинацию (назовем if Key) и сгруппируем элементы по их Key:

data class Key(val shiftId: String, val createUserId: String, val nozzleId: String)
fun NozzleState.toKey() = Key(shift.id, createUser.id, nozzle.id)

nozzleStateList.groupBy { it.toKey() }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...