KotlinでJSONをパースする方法!初心者向けGson・Moshiの使い分けガイド
生徒
「Kotlinでインターネットから取得したデータを扱いたいんですけど、JSONってどうやって使うんですか?」
先生
「KotlinではJSON(ジェイソン)というデータ形式を扱うために、Gson(ジーソン)やMoshi(モシ)というライブラリを使ってパース(解析)するのが一般的です。」
生徒
「GsonとMoshiってどう違うんですか?どっちを使えばいいのか迷います…」
先生
「良い疑問ですね。今回はGsonとMoshiの基本的な使い方と、どう使い分ければいいかを初心者向けにわかりやすく解説していきます!」
1. JSONってなに?Kotlinで使う理由
JSON(JavaScript Object Notation)は、データのやりとりによく使われる軽量なフォーマットです。たとえば、天気情報アプリなどでインターネット経由で受け取るデータは、ほとんどがJSON形式です。
JSONは中身が「名前」と「値」のセットになっていて、文字でやりとりされます。KotlinでWeb APIと連携する際には、このJSONを読み込んで、Kotlinのクラス(データクラス)に変換して扱いやすくします。
2. JSONをパースするとは?
「パースする」とは、文字列になっているJSONをプログラムで読み取って、意味のあるデータに変換することです。たとえば、以下のようなJSON文字列があったとします。
{
"name": "Taro",
"age": 25
}
このようなデータを、KotlinのPersonクラスに変換することで、プログラムで扱いやすくなります。
3. Gsonの使い方(Google製ライブラリ)
Gson(ジーソン)はGoogleが提供しているJSONパーサーライブラリです。設定が少なくても使えるので初心者にもおすすめです。
まずは、build.gradle.kts(Gradleの設定ファイル)にGsonの依存関係を追加します。
dependencies {
implementation("com.google.code.gson:gson:2.10.1")
}
次に、JSONデータを読み込むためのKotlinコードを見てみましょう。
import com.google.gson.Gson
data class Person(val name: String, val age: Int)
fun main() {
val json = """{"name":"Taro","age":25}"""
val gson = Gson()
val person = gson.fromJson(json, Person::class.java)
println(person)
}
Person(name=Taro, age=25)
このように、Gsonを使うとJSONを簡単にKotlinのデータクラスへ変換できます。
4. Moshiの使い方(Square製ライブラリ)
Moshi(モシ)はSquare社が開発したJSONライブラリで、Kotlinとの相性が良く、最近ではGsonの代わりとして注目されています。
まず、GradleにMoshiの依存を追加します。
dependencies {
implementation("com.squareup.moshi:moshi:1.15.0")
implementation("com.squareup.moshi:moshi-kotlin:1.15.0")
}
Moshiでは、Kotlinの拡張機能を使うためにmoshi-kotlinも一緒に入れる必要があります。
import com.squareup.moshi.Moshi
import com.squareup.moshi.kotlin.reflect.KotlinJsonAdapterFactory
data class Person(val name: String, val age: Int)
fun main() {
val json = """{"name":"Taro","age":25}"""
val moshi = Moshi.Builder()
.add(KotlinJsonAdapterFactory())
.build()
val adapter = moshi.adapter(Person::class.java)
val person = adapter.fromJson(json)
println(person)
}
Person(name=Taro, age=25)
Moshiは型安全で、Kotlinのnull対応も強力にサポートしています。
5. GsonとMoshiの違いと使い分け
では、GsonとMoshiはどう違って、どちらを選べばよいのでしょうか?
| 特徴 | Gson | Moshi |
|---|---|---|
| 開発元 | Square | |
| Kotlin対応 | やや弱め | 強い |
| 速度 | やや遅め | 高速 |
| 拡張性 | 高い | 高い |
| 初心者向け | ◎ | ○ |
もしこれから初めてJSONパースを試すなら、Gsonの方が導入しやすくおすすめです。ですが、Kotlinとの親和性を重視する場合や大規模開発ではMoshiの方が適しています。
Kotlinを基礎からしっかり学びたい人や、 Java経験を活かしてモダンな言語にステップアップしたい人には、 定番の入門書がこちらです。
基礎からわかるKotlinをAmazonで見る※ Amazon広告リンク
6. JSONの構造が複雑なときは?
実際の開発では、もっとネストが深かったり、リストを含んだJSONもよくあります。そういった複雑なJSONでも、GsonもMoshiもデータクラスをうまく設計すれば対応可能です。
たとえば、以下のようなJSONなら
{
"person": {
"name": "Taro",
"age": 25
}
}
この場合、PersonWrapperというクラスを作って、さらに中にPersonを入れるようにすればOKです。
data class PersonWrapper(val person: Person)
このように、JSONの構造に合わせてデータクラスをネストすれば、複雑なデータでも安全に扱えるようになります。
【未経験OK】Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験する60分
「プログラミングを始めたい」を形にする。最新言語Kotlinで楽しむ、ものづくりの第一歩。
本講座は、プログラミング経験が全くない方のためのエントリー講座です。「コードを書くってどういうこと?」という基本から、世界中で使われている最新言語Kotlin(コトリン)を使って、実際にプログラムを動かすまでを体験します。難しい理屈よりも、まずは「自分の手で動かす楽しさ」を最短距離で実感していただきます。
具体的な体験内容と環境
【つくるもの】
簡単な言葉を入力すると自動で返答してくれる「対話型ミニプログラム」や、計算を自動化する「便利ツール」をゼロから作成します。黒い画面に自分の書いた文字が表示される瞬間は、最高の感動体験です。
【開発環境】
プロのエンジニアが実際に使っている開発ツールIntelliJ IDEA(インテリジェイ)をインストールします。ボタン一つで日本語化し、初心者でも迷わず操作できる「魔法の設定」を一緒に行います。
この60分で得られる3つの体験
プロと同じ道具を揃えることで、明日から一人でもプログラミングを続けられる環境が整います。
「変数」や「型」といった難しい言葉も、身近な例え話で解説。モヤモヤをゼロにします。
Kotlinは英語に近くて読みやすいのが特徴。自分でコードを読んで、間違いを見つけるコツも伝授します。
※本講座は、パソコン操作が不安な方でも安心して受講いただける完全マンツーマンです。あなたのペースに合わせて、一つずつ丁寧に進めていきます。
Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験