Kotlin:
CSVとの作業

方法:

Kotlinは静的型付けプログラミング言語であり、JVM上で実行されますが、CSVファイルを扱うための組み込みライブラリを含んでいません。しかし、基本的な操作のためにJavaのBufferedReaderFileWriterクラスを使用することができます。また、より高度な機能には、kotlinx.serializationopencsvのような人気のあるサードパーティライブラリを活用できます。

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ファイルを操作する際の柔軟性を示しており、プロジェクトのニーズに最も合った方法を選択できます。