Kotlin:
CSVとの作業
方法:
Kotlinは静的型付けプログラミング言語であり、JVM上で実行されますが、CSVファイルを扱うための組み込みライブラリを含んでいません。しかし、基本的な操作のためにJavaのBufferedReader
とFileWriter
クラスを使用することができます。また、より高度な機能には、kotlinx.serialization
やopencsv
のような人気のあるサードパーティライブラリを活用できます。
BufferedReaderを使用したCSVファイルの読み取り:
import java.io.BufferedReader
import java.io.FileReader
fun main() {
val path = "data.csv"
val br = BufferedReader(FileReader(path))
br.useLines { lines ->
lines.forEach { line ->
val cols = line.split(',')
println(cols)
}
}
}
サンプル出力:
[Name, Age, City]
[John Doe, 30, New York]
[Jane Smith, 25, London]
FileWriterを使用したCSVファイルへの書き込み:
import java.io.FileWriter
fun main() {
val data = listOf(
listOf("Name", "Age", "City"),
listOf("John Doe", "30", "New York"),
listOf("Jane Smith", "25", "London")
)
FileWriter("output.csv").use { writer ->
data.forEach { row ->
writer.write(row.joinToString(",") + "\n")
}
}
}
これにより、提供されたデータでoutput.csv
が作成または上書きされます。
kotlinx.serializationを使用したCSVシリアライゼーション:
まず、build.gradle.kts
に依存関係を追加します:
implementation("org.jetbrains.kotlinx:kotlinx-serialization-csv:0.3.0")
注: 正しいバージョンとリポジトリの設定を確認してください。
次に、データクラスを定義し、シリアライゼーションにCsv
フォーマットを使用します:
import kotlinx.serialization.Serializable
import kotlinx.serialization.csv.Csv
import kotlinx.serialization.encodeToString
@Serializable
data class Person(val name: String, val age: Int, val city: String)
fun main() {
val csvFormat = Csv { delimiter = ',' }
val data = listOf(
Person("John Doe", 30, "New York"),
Person("Jane Smith", 25, "London")
)
val csvData = csvFormat.encodeToString(data)
println(csvData)
}
サンプル出力:
John Doe,30,New York
Jane Smith,25,London
OpenCSVを使用した高度な操作:
プロジェクトの依存関係にOpenCSVを追加します:
implementation("com.opencsv:opencsv:5.6")
OpenCSVでの読み取りと書き込み:
import com.opencsv.CSVReader
import com.opencsv.CSVWriter
import java.io.FileReader
import java.io.FileWriter
fun main() {
// CSVの読み取り
CSVReader(FileReader("data.csv")).use { csvReader ->
val entries = csvReader.readAll()
entries.forEach { println(it.toList()) }
}
// CSVの書き込み
CSVWriter(FileWriter("output.csv")).use { csvWriter ->
val entries = listOf(
arrayOf("Name", "Age", "City"),
arrayOf("John Doe", "30", "New York"),
arrayOf("Jane Smith", "25", "London")
)
csvWriter.writeAll(entries)
}
}
これらのコードスニペットは、KotlinがCSVファイルを操作する際の柔軟性を示しており、プロジェクトのニーズに最も合った方法を選択できます。