-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDataClasses.kt
44 lines (36 loc) · 1.57 KB
/
DataClasses.kt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
@file:Suppress("UnusedImport")
import org.jetbrains.kotlinx.dataframe.*
import org.jetbrains.kotlinx.dataframe.annotations.*
import org.jetbrains.kotlinx.dataframe.api.*
import org.jetbrains.kotlinx.dataframe.io.*
@DataSchema
data class Person(val firstName: String, val lastName: String, val age: Int, val city: String?)
@DataSchema
data class Group(val id: String, val participants: List<Person>)
@DataSchema
class WikiData(val name: String, val paradigms: List<String>)
fun main() {
// Possible to create DataFrame from DataSchema objects, converting nested DataSchema objects to ColumnGroup and lists of DataSchema to FrameColumn
val languages = dataFrameOf(
WikiData("Kotlin", listOf("object-oriented", "functional", "imperative")), // Kotlin
WikiData("Haskell", listOf("Purely functional")), // Haskell
WikiData("C", listOf("imperative")), // C
WikiData("Pascal", listOf("imperative")), // Pascal
WikiData("Idris", listOf("functional")), // Idris
WikiData("OCaml", listOf("functional", "imperative", "modular", "object-oriented")) // OCaml
)
languages.name.print()
languages.paradigms.print()
// Same here but with an arbitrary level of nesting
val df = listOf(
Group("1", listOf(
Person("Alice", "Cooper", 15, "London"),
Person("Bob", "Dylan", 45, "Dubai")
)),
Group("2", listOf(
Person("Charlie", "Daniels", 20, "Moscow"),
Person("Charlie", "Chaplin", 40, "Milan"),
)),
).toDataFrame(maxDepth = 2)
df.participants[0].age.print()
}