カテゴリ: Swift 更新日: 2026/01/23

Swift Codable×コレクション完全ガイド!初心者でもわかるJSON配列のdecode/encode

Swift Codable×コレクション|JSON配列のdecode/encode実践
Swift Codable×コレクション|JSON配列のdecode/encode実践

先生と生徒の会話形式で理解しよう

生徒

「SwiftでJSONを配列や辞書に変換する方法ってありますか?」

先生

「はい、SwiftにはCodableという仕組みがあって、JSONをArrayDictionarySetといったコレクション型に簡単に変換できます。」

生徒

「難しそうに聞こえますけど、実際にはどうやるんですか?」

先生

「それでは、初心者でもわかるように、基本から順番に解説していきましょう!」

1. SwiftのCodableとは?

1. SwiftのCodableとは?
1. SwiftのCodableとは?

SwiftのCodableは、データを別の形式に変換するための仕組みです。特に、JSONと呼ばれるデータ形式をSwiftのオブジェクトに変換(decode)したり、逆にSwiftのオブジェクトをJSONに変換(encode)するのに使われます。

JSON(ジェイソン)は、インターネットで広く使われているデータのやりとりのフォーマットです。人間が読んでも分かりやすく、コンピュータでも扱いやすいという特徴があります。

2. Codableとコレクション型の基本

2. Codableとコレクション型の基本
2. Codableとコレクション型の基本

Swiftには代表的なコレクション型として、Array(配列)、Dictionary(辞書)、Set(集合)があります。これらはデータをまとめて扱うときに便利です。

  • Array:順番があるリスト。例:りんご、バナナ、みかん
  • Dictionary:キーと値の組み合わせ。例:「名前」→「山田」、「年齢」→「20」
  • Set:重複を許さない集まり。例:「A」「B」「C」だけが一度ずつ入る

Codableは、これらのコレクション型と組み合わせることで、複数のデータをまとめてJSONとやり取りすることが可能になります。

3. JSON配列をSwiftのArrayに変換(decode)

3. JSON配列をSwiftのArrayに変換(decode)
3. JSON配列をSwiftのArrayに変換(decode)

まずはJSONの配列をSwiftのArrayに変換する例を見てみましょう。ここでは「ユーザー」のデータを配列として扱います。


import Foundation

struct User: Codable {
    let id: Int
    let name: String
}

let json = """
[
    { "id": 1, "name": "田中" },
    { "id": 2, "name": "佐藤" }
]
""".data(using: .utf8)!

do {
    let users = try JSONDecoder().decode([User].self, from: json)
    print(users)
} catch {
    print("デコードに失敗しました: \(error)")
}

[User(id: 1, name: "田中"), User(id: 2, name: "佐藤")]

このように、JSON配列をそのままSwiftの配列に変換することができます。

4. Swiftの配列をJSONに変換(encode)

4. Swiftの配列をJSONに変換(encode)
4. Swiftの配列をJSONに変換(encode)

逆に、Swiftの配列をJSONに変換することも可能です。これをencodeといいます。


let users = [
    User(id: 1, name: "田中"),
    User(id: 2, name: "佐藤")
]

do {
    let jsonData = try JSONEncoder().encode(users)
    if let jsonString = String(data: jsonData, encoding: .utf8) {
        print(jsonString)
    }
} catch {
    print("エンコードに失敗しました: \(error)")
}

[{"id":1,"name":"田中"},{"id":2,"name":"佐藤"}]

Swiftの配列をそのままJSONの配列に変換できるので、サーバーとのデータ通信にも役立ちます。

5. DictionaryとCodable

5. DictionaryとCodable
5. DictionaryとCodable

Dictionaryはキーと値の組み合わせでデータを扱います。JSONでも同じように「キー」と「値」の形式がよく使われるので、相性が良いです。


let json = """
{
    "user1": { "id": 1, "name": "田中" },
    "user2": { "id": 2, "name": "佐藤" }
}
""".data(using: .utf8)!

do {
    let users = try JSONDecoder().decode([String: User].self, from: json)
    print(users)
} catch {
    print("デコードに失敗しました: \(error)")
}

["user1": User(id: 1, name: "田中"), "user2": User(id: 2, name: "佐藤")]

6. SetとCodable

6. SetとCodable
6. SetとCodable

Setは重複を許さない特徴があり、JSON配列を変換する際にも使うことができます。例えば重複データを排除したいときに便利です。


let json = """
[
    { "id": 1, "name": "田中" },
    { "id": 1, "name": "田中" },
    { "id": 2, "name": "佐藤" }
]
""".data(using: .utf8)!

do {
    let users = try JSONDecoder().decode(Set<User>.self, from: json)
    print(users)
} catch {
    print("デコードに失敗しました: \(error)")
}

[User(id: 1, name: "田中"), User(id: 2, name: "佐藤")]

同じ「田中」のデータが2つあっても、自動的に1つにまとめてくれるのが特徴です。

7. Codableとエラーハンドリング

7. Codableとエラーハンドリング
7. Codableとエラーハンドリング

JSONとSwiftの型が一致しないと、エラーになることがあります。そのため、do-catch構文を使って失敗した場合の処理を用意するのが基本です。

初心者の方は、まずは正しくデータ型を合わせることを意識すると、スムーズにコーディングできます。

Swiftを基礎から実践レベルまで学びたい人や、 iOSアプリ開発を本格的に始めたい人には、 定番の入門+実践書がこちらです。

Swift実践入門をAmazonで見る

※ Amazon広告リンク

8. 理解ポイント

8. 理解ポイント
8. 理解ポイント

この記事では、SwiftのCodableとコレクション型(ArrayDictionarySet)を使って、JSONとの変換方法を学びました。これらを理解することで、実際のアプリ開発でもサーバーとデータをやり取りする仕組みがしっかり理解できるようになります。

関連セミナーのご案内

Windowsで始めるiPhoneアプリ開発入門|Swiftの基本と仕組みを1時間で攻略

Windowsで始めるiPhoneアプリ開発入門|Swiftの基本と仕組みを1時間で攻略

「iPhoneアプリを作りたいけれど、Macを持っていないから諦めている」そんな方のための画期的な入門講座です。実は、プログラミングの本質を学ぶのに高価な機材は必要ありません。本講座では、Windowsパソコンを使用し、クラウド環境を活用してAppleの最新言語Swift(スウィフト)の基礎を最短距離でマスターします。

Windowsで実現する開発環境

【つくるもの】
ブラウザ上で動作する「スマート・計算ツール」や「データ判定プログラム」をゼロから作成します。変数の扱いや条件分岐など、iPhoneアプリの内部で動くロジックを自分の手で構築する感動を体験してください。

【開発環境】
ブラウザだけでSwiftが動くプロ仕様のオンラインエディタ(Replit等)を使用します。面倒な設定は一切不要。今あるWindows PCで、プロのエンジニアと同じコードを書き始められます。

この60分で得られる3つの理解

1. WindowsでのSwift実行環境の作り方

OSの壁を越え、クラウドを活用してスマートに学習を開始する「現代的な開発スタイル」を習得します。

2. Swiftの基本構造(変数・型・定数)

iPhoneアプリ特有のデータの扱い方や、Appleが推奨する「安全で美しいコード」の書き方を学びます。

3. アプリエンジニアとしてのロードマップ

将来的にiOSエンジニアとして副業・転職するために必要な準備や、Mac選びのポイントを伝授します。

※本講座は、将来的にiPhoneアプリ開発で収益化や転職を目指したい未経験者のためのエントリー講座です。マンツーマン形式により、Windows環境ならではの疑問にもその場でお答えし、あなたの理解度に合わせて進行します。

セミナー画像

Windowsで始めるiPhoneアプリ開発入門

関連記事:
カテゴリの一覧へ
新着記事
New1
Go言語
Go言語のwhile的なforループの使い方!条件式ループの基本を解説
New2
Go言語
Go言語プログラムの実行方法まとめ!VSCode・ターミナルでの実行手順を解説
New3
Swift
Swift意味とは?プログラミング言語・金融・鳥の違いを徹底解説
New4
Swift
Swift 戻り値の扱い方と複数戻り値の返し方|初心者でも分かる関数の基本
人気記事
No.1
Java&Spring記事人気No1
Go言語
Go言語でリダイレクト処理を行う方法(http.Redirect)を初心者向けに解説
No.2
Java&Spring記事人気No2
Swift
Swift開発環境の構築方法を徹底解説!Xcode・Windows・Linux対応
No.3
Java&Spring記事人気No3
Kotlin
Android Studioのインストール手順と初期設定を初心者向けに完全解説!
No.4
Java&Spring記事人気No4
Kotlin
Gradleファイル(build.gradle.kts)の書き方と役割をやさしく解説!Kotlin初心者向け完全ガイド
No.5
Java&Spring記事人気No5
Go言語
Go言語のgo.modファイル完全ガイド!初心者でもわかる仕組みと書き方
No.6
Java&Spring記事人気No6
Go言語
Go言語で条件式を1行で書くコツ!三項演算子の代替と短縮記法
No.7
Java&Spring記事人気No7
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方
No.8
Java&Spring記事人気No8
Kotlin
Kotlinのログ出力方法を完全ガイド!LogcatとTimberでトラブルシューティング