KotlinのjoinToString関数!使い方と応用の10選 – Japanシーモア

KotlinのjoinToString関数!使い方と応用の10選

KotlinのjoinToString関数を使ったプログラムのイメージ図Kotlin
この記事は約18分で読めます。

 

【サイト内のコードはご自由に個人利用・商用利用いただけます】

このサービスは複数のSSPによる協力の下、運営されています。

この記事では、プログラムの基礎知識を前提に話を進めています。

説明のためのコードや、サンプルコードもありますので、もちろん初心者でも理解できるように表現してあります。

基本的な知識があればカスタムコードを使って機能追加、目的を達成できるように作ってあります。

※この記事は、一般的にプロフェッショナルの指標とされる『実務経験10,000時間以上』を凌駕する現役のプログラマチームによって監修されています。

サイト内のコードを共有する場合は、参照元として引用して下さいますと幸いです

※Japanシーモアは、常に解説内容のわかりやすさや記事の品質に注力しております。不具合、分かりにくい説明や不適切な表現、動かないコードなど気になることがございましたら、記事の品質向上の為にお問い合わせフォームにてご共有いただけますと幸いです。
(送信された情報は、プライバシーポリシーのもと、厳正に取扱い、処分させていただきます。)

はじめに

Kotlinという言葉を耳にすることが増えてきたのではないでしょうか。

KotlinはAndroidアプリケーション開発の公式言語として採用されており、多くの開発者がその魅力に取り組んでいます。

そんなKotlinには、さまざまな便利な関数が用意されていますが、中でもjoinToString関数は非常に強力なツールとして知られています。

この記事を読むことで、joinToString関数の基本的な使い方から、より高度な応用例までをしっかりと掴むことができるようになります。

特に初心者の方でも、サンプルコードを元にスムーズに理解できる内容となっておりますので、是非最後までお付き合いください。

●joinToString関数とは

joinToString関数は、Kotlinのコレクションや配列などの要素を一つの文字列にまとめる際に非常に役立つ関数です。

例えば、リスト内の要素をカンマで区切った文字列として出力したい場合や、特定の条件を満たす要素だけを取り出して文字列化したい場合など、さまざまなシチュエーションで活躍します。

○joinToString関数の基本

joinToString関数の基本的な使い方を見てみましょう。

この関数を利用すると、リストや配列の要素を特定の区切り文字で結合し、一つの文字列として出力することができます。

下記のコードは、数値のリストを,(カンマ)で結合して一つの文字列として出力するシンプルな例です。

fun main() {
    val numbers = listOf(1, 2, 3, 4, 5)
    val result = numbers.joinToString(separator = ",")
    println(result)
}

このコードでは、listOf関数を使って1から5までの数値を持つリストを作成しています。

そして、joinToString関数を用いてリストの要素を,で結合しています。

このコードを実行すると、次のような結果を得られます。

1,2,3,4,5

●joinToString関数の使い方

KotlinのjoinToString関数は、非常に強力であり、様々なオプションを持っているため、まずはその基本的な使い方から探ることにします。

この関数は、配列やリストに格納された要素を文字列に変換し、結合する際に役立ちます。

○サンプルコード1:基本的なリストを文字列に変換する

まずは最も基本的な使い方を見ていきましょう。

リストに格納された文字を、そのまま文字列として連結する方法です。

fun main() {
    val fruits = listOf("apple", "banana", "cherry")
    val result = fruits.joinToString()
    println(result) // コメント: apple, banana, cherryを出力
}

このコードでは、listOf関数を使って文字列のリストを作成しています。

そして、joinToString関数を利用することで、リスト内の全ての要素をデフォルトの区切り文字,(カンマ)で結合しています。

このコードを実行すると、リスト内の文字列”apple”, “banana”, “cherry”がカンマで区切られた状態で出力されます。

○サンプルコード2:セパレータを変更してリストを文字列に変換する

次に、区切り文字をカスタマイズする方法を見ていきます。

joinToString関数のseparatorパラメータを利用することで、区切り文字を自由に変更できます。

fun main() {
    val colors = listOf("red", "green", "blue")
    val result = colors.joinToString(separator = " - ")
    println(result) // コメント: red - green - blueを出力
}

このコードでは、listOf関数を使って色の名前を持つリストを作成しています。

そして、joinToString関数のseparatorパラメータに” – “を設定することで、リスト内の要素をハイフンで結合しています。

このコードを実行すると、リスト内の文字列”red”, “green”, “blue”がハイフンで区切られた状態で出力されます。

○サンプルコード3:prefixとpostfixを使用してリストを文字列に変換する

KotlinのjoinToString関数は、単純な文字列の結合だけでなく、接頭辞や接尾辞を追加する機能も持っています。

これにより、リスト全体の前後に任意の文字列を追加することができます。

例として、数値のリストを取り、そのリストを括弧で囲んだ文字列に変換するケースを考えます。

fun main() {
    val numbers = listOf(1, 2, 3, 4, 5)
    val result = numbers.joinToString(prefix = "[", postfix = "]")
    println(result) // コメント: [1, 2, 3, 4, 5]を出力
}

このコードでは、数値のリストを定義し、joinToString関数のprefixpostfixパラメータを使用して、リストの先頭に[、リストの末尾に]を追加しています。

実際にこのコードを実行すると、[1, 2, 3, 4, 5]という形式の文字列が出力されます。

○サンプルコード4:limitとtruncatedを使用してリストを部分的に文字列に変換する

大量のデータが格納されているリストがある場合、その全てを文字列に変換するのは非効率的であり、読むのも大変です。

このような場合、joinToString関数のlimittruncatedのオプションを使うことで、リストの一部だけを取り出して文字列化することができます。

例として、多数の要素を持つリストから先頭の3つだけを取り出し、その後に...を追加して文字列化するケースを見てみましょう。

fun main() {
    val numbers = listOf(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
    val result = numbers.joinToString(limit = 3, truncated = "...")
    println(result) // コメント: 1, 2, 3...を出力
}

このコードでは、10の要素を持つ数値のリストを作成し、joinToString関数を使用しています。

limitパラメータに3を指定することで、リストから最初の3つの要素だけを取得しています。

さらに、truncatedパラメータに...を指定することで、取得した3つの要素の後に...が追加されるようになっています。

このコードを実行すると、1, 2, 3...という文字列が出力されます。

このように、大量のデータを持つリストから一部だけを効果的に文字列化する方法は、特にデータのプレビュー表示などで非常に役立ちます。

●joinToString関数の応用例

KotlinのjoinToString関数は、その柔軟性と多機能性からさまざまな応用が考えられます。

ここでは、その中でも特に実用的で役立ついくつかの応用例を紹介します。

○サンプルコード5:カスタムオブジェクトのリストを文字列に変換する

リストの要素がプリミティブなデータ型である場合だけでなく、カスタムオブジェクトのリストを文字列化することも可能です。

考えられるケースとして、Personクラスのオブジェクトのリストを持っており、そのリストを文字列化したいとします。

この時、各オブジェクトのnameプロパティだけを取り出して、カンマ区切りの文字列に変換することを考えます。

data class Person(val name: String, val age: Int)

fun main() {
    val people = listOf(
        Person("山田", 25),
        Person("佐藤", 30),
        Person("田中", 22)
    )

    val names = people.joinToString(separator = ", ") { it.name }
    println(names) // コメント: 山田, 佐藤, 田中 と表示
}

このコードでは、Personというデータクラスを定義し、そのオブジェクトのリストを作成しています。

joinToString関数にラムダ式を渡すことで、リストの各オブジェクトからnameプロパティだけを取り出して文字列化しています。

実行結果として、山田, 佐藤, 田中という文字列が得られます。

○サンプルコード6:joinToString関数を使った簡単なデータのフォーマット

joinToString関数はデータのフォーマットにも役立ちます。

例えば、与えられた日付のリストを、特定の形式で文字列化したい場合を考えてみましょう。

fun main() {
    val dates = listOf("2023-10-01", "2023-10-02", "2023-10-03")
    val formattedDates = dates.joinToString(separator = " ~ ") 
    println(formattedDates) // コメント: 2023-10-01 ~ 2023-10-02 ~ 2023-10-03 と表示
}

このコードでは、datesという日付のリストを定義し、それをjoinToString関数で~を区切り文字として文字列化しています。

実行結果として、2023-10-01 ~ 2023-10-02 ~ 2023-10-03というフォーマットの文字列が得られます。

○サンプルコード7:joinToString関数とlambda式を組み合わせる

joinToString関数は、特定の処理を行いながらリストの各要素を文字列に変換する場合、ラムダ式との組み合わせが非常に便利です。

ラムダ式を使用することで、リストの各要素に対してカスタムな処理を適用した後、その結果を元に文字列変換を行うことができます。

例として、整数のリストを持っていて、そのリストの各要素を2倍した値を持つ文字列を作成するケースを考えます。

fun main() {
    val numbers = listOf(1, 2, 3, 4, 5)
    val doubledString = numbers.joinToString(separator = ", ") { (it * 2).toString() }
    println(doubledString) // コメント: 2, 4, 6, 8, 10 と表示されます。
}

このコードはnumbersという整数のリストを定義し、joinToString関数にラムダ式を渡しています。

ラムダ式内では、リストの各要素を2倍して、その結果を文字列に変換しています。

その結果、2, 4, 6, 8, 10という文字列が得られることが確認できます。

このように、joinToString関数とラムダ式を組み合わせることで、リストの各要素に対して柔軟な処理を適用しながら文字列変換を行うことができます。

○サンプルコード8:nullを含むリストを文字列に変換する

場合によっては、リストの中にnullを含むことがあります。

nullを含むリストを文字列に変換する際、joinToString関数はnullの扱いに注意が必要です。

考えられるケースとして、文字列とnullが混在するリストを持っていて、そのリストを文字列化する際にnullの部分は特定の文字列で置き換えたいとします。

fun main() {
    val values = listOf("apple", null, "banana", null, "cherry")
    val resultString = values.joinToString(separator = ", ") { it ?: "unknown" }
    println(resultString) // コメント: apple, unknown, banana, unknown, cherry と表示されます。
}

このコードはvaluesというnullを含むリストを定義し、joinToString関数とラムダ式を使用して、nullの部分をunknownという文字列に置き換えています。

その結果、apple, unknown, banana, unknown, cherryという文字列が得られます。

このように、joinToString関数を使えば、nullを特定の文字列で置き換えながらリストを文字列化することが容易になります。

○サンプルコード9:joinToString関数を使ってCSVファイルの内容を整形する

CSV(Comma-Separated Values)は、データをカンマで区切る形式で表現するテキストデータの形式です。

多くのアプリケーションやシステムで広く用いられています。

KotlinのjoinToString関数を利用することで、リストや配列の内容を簡単にCSV形式の文字列に変換することができます。

例えば、名前と年齢のペアを持つデータリストがあり、このリストの内容をCSV形式の文字列に変換したい場合を考えます。

data class Person(val name: String, val age: Int)

fun main() {
    val people = listOf(
        Person("山田太郎", 25),
        Person("鈴木花子", 30),
        Person("佐藤一郎", 35)
    )

    val csvString = people.joinToString(separator = "\n") { "${it.name}, ${it.age}" }
    println(csvString) // コメント: 山田太郎, 25
                       //           鈴木花子, 30
                       //           佐藤一郎, 35 と表示されます。
}

このコードでは、まずPersonというデータクラスを定義しています。

そして、peopleというPersonオブジェクトのリストを作成しています。

最後に、joinToString関数とラムダ式を使用して、peopleの各要素をCSV形式の文字列に変換しています。

結果として、各行に名前, 年齢の形式でデータが並ぶ文字列が得られます。

この方法を活用すれば、データベースの出力結果や、各種データの集計結果など、様々なデータを効率よくCSV形式で出力することができます。

さらに、この方法を組み合わせることで、CSVファイルの入出力や、データの加工など、多岐にわたるタスクを簡単に実現することができます。

○サンプルコード10:joinToString関数を拡張関数としてカスタマイズする

Kotlinは拡張関数という特徴的な機能を持っています。

これを利用することで、既存のクラスや関数に新しい機能を追加することができます。

joinToString関数もカスタマイズするための拡張関数として定義することができます。

例として、特定の条件に合致する要素のみを取り出して、文字列に変換する拡張関数を考えます。

fun List<Int>.joinEvenNumbersToString(separator: String = ", "): String {
    return this.filter { it % 2 == 0 }.joinToString(separator)
}

fun main() {
    val numbers = listOf(1, 2, 3, 4, 5, 6)
    val result = numbers.joinEvenNumbersToString()
    println(result) // コメント: 2, 4, 6 と表示されます。
}

このコードでは、List<Int>に対する拡張関数joinEvenNumbersToStringを定義しています。

この関数は、リストから偶数の要素のみを取り出し、それらを指定されたセパレータで結合して文字列に変換します。

main関数内では、この拡張関数を呼び出して結果を表示しています。

このように、拡張関数を利用すれば、joinToString関数をベースにして、独自のカスタマイズを行った関数を簡単に定義することができます。

これにより、プログラムの再利用性や可読性が向上し、開発効率も大幅にアップします。

●注意点と対処法

KotlinのjoinToString関数は非常に便利で、多岐にわたる処理に応用することができます。

しかし、この関数を利用する際には、いくつかの注意点が存在します。

ここでは、その注意点と、それに対する対処法を詳細に解説します。

○null値の取り扱い

joinToString関数を利用する際、リスト内にnull値が含まれている場合、そのnull値の扱いに注意が必要です。

val listWithNulls = listOf("A", null, "B", "C")
val result = listWithNulls.joinToString()
println(result)  // コメント: A, null, B, C と出力されます。

上記のコードでは、listWithNullsというnull値を含むリストに対してjoinToString関数を実行しています。

このとき、null値は”null”という文字列として出力されます。

これを避けるためには、filterNotNull関数を利用してnull値を除去することが推奨されます。

val resultWithoutNulls = listWithNulls.filterNotNull().joinToString()
println(resultWithoutNulls)  // コメント: A, B, C と出力されます。

○大量のデータに対するパフォーマンス

大量のデータを持つリストや配列を扱う際、joinToString関数の実行には時間がかかる可能性があります。

そのため、非常に多くのデータを処理する際は、パフォーマンスの観点から注意が必要です。

特に、ループ内でjoinToString関数を頻繁に実行するような場合には、パフォーマンスの低下が考えられます。

○カスタムオブジェクトの変換

joinToString関数は、基本的にオブジェクトのtoStringメソッドの結果を使用して文字列変換を行います。

そのため、カスタムオブジェクトをリストに持つ場合、そのオブジェクトのtoStringメソッドの実装によって、変換後の結果が大きく変わる可能性があります。

期待する結果を得るためには、カスタムオブジェクトのtoStringメソッドを適切にオーバーライドすることが重要です。

●カスタマイズ方法

KotlinのjoinToString関数は非常に汎用性が高いため、多くの場面でそのままの形で利用することができます。

しかし、特定の用途や状況に合わせて、この関数をカスタマイズしたい場合もあるでしょう。

ここでは、joinToString関数をカスタマイズする方法をいくつか解説します。

○拡張関数を利用する

Kotlinでは、既存のクラスに新しい関数を追加することができる拡張関数という機能があります。

この機能を利用して、joinToString関数を独自に拡張することができます。

fun List<String>.joinWithAsterisk(): String {
    return this.joinToString(separator = "*")
}

val list = listOf("A", "B", "C")
val result = list.joinWithAsterisk()
println(result)  // コメント: A*B*C と表示されます。

このコードでは、セパレータとしてアスタリスクを使用するjoinWithAsteriskという拡張関数を定義しています。

これを利用することで、特定のセパレータを持つ文字列への変換を簡単に行うことができます。

○高階関数を利用する

joinToString関数には、変換をカスタマイズするためのtransform引数が存在します。

これを利用することで、リストの各要素を任意の方法で変換してから文字列として連結することができます。

val numbers = listOf(1, 2, 3, 4, 5)
val result = numbers.joinToString(separator = ", ") { "No.$it" }
println(result)  // コメント: No.1, No.2, No.3, No.4, No.5 と表示されます。

このコードでは、transform引数にラムダ式を渡して、リストの各要素を”No.[要素の値]”という形式に変換しています。

○カスタムクラスでの利用

カスタムクラスのリストをjoinToString関数で処理する場合、そのクラスのtoStringメソッドをオーバーライドすることで出力結果をカスタマイズすることができます。

data class Person(val name: String, val age: Int) {
    override fun toString(): String {
        return "$name ($age歳)"
    }
}

val persons = listOf(Person("太郎", 20), Person("花子", 25))
val result = persons.joinToString(separator = "、")
println(result)  // コメント: 太郎 (20歳)、花子 (25歳) と表示されます。

このコードでは、PersonクラスのtoStringメソッドをオーバーライドして、名前と年齢を特定のフォーマットで出力するようにしています。

まとめ

KotlinのjoinToString関数は、リストやコレクションの内容を特定の形式の文字列として結合する際に非常に有用です。

その基本的な使い方から、さまざまなオプションを利用した応用例、さらにはカスタマイズ方法まで、多岐にわたる利用法があります。

初心者から上級者まで、この関数の使い方をマスターすることで、日常のコーディング作業がよりスムーズに、効率的に行えるようになるでしょう。

また、Kotlinの豊富な機能と組み合わせることで、joinToString関数の可能性はさらに広がります。

特に、拡張関数や高階関数を駆使することで、独自のニーズに合わせた処理を追加することも可能です。

今回の記事を通じて、KotlinのjoinToString関数の魅力とその応用方法について理解を深めることができたことを願っています。

日々の開発作業での新たなチャレンジや問題解決の一助となることを期待しています。