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

Swift JSONデコード失敗の原因と対処|DecodingError徹底解説

Swift JSONデコード失敗の原因と対処|DecodingError徹底解説
Swift JSONデコード失敗の原因と対処|DecodingError徹底解説

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

生徒

「SwiftでJSONを読み込もうとしたらエラーになってしまいました。どうしてなんでしょうか?」

先生

「SwiftではJSONDecoderを使ってJSONをSwiftの構造体やクラスに変換しますが、そのときに形式が合わないとエラーになります。」

生徒

「エラーって具体的にはどんな種類があるんですか?」

先生

「良い質問です。SwiftにはDecodingErrorという仕組みがあり、どの部分で失敗したかを詳しく教えてくれます。それでは、具体的に見ていきましょう。」

1. SwiftのJSONデコードとは?

1. SwiftのJSONデコードとは?
1. SwiftのJSONデコードとは?

まず「JSON」とは、データをやりとりするためのフォーマットの一つで、JavaScript Object Notationの略です。人間が読めるテキスト形式で、アプリやサーバー間の通信でよく使われます。

Swiftでは、サーバーから受け取ったJSONをアプリ内で使えるようにstructclassに変換します。この変換処理を「JSONデコード」と呼び、JSONDecoderクラスを利用します。

2. DecodingErrorとは?

2. DecodingErrorとは?
2. DecodingErrorとは?

SwiftのJSONデコードが失敗したときに発生する代表的なエラーがDecodingErrorです。このエラーは「なぜ変換できなかったのか」を教えてくれるので、原因を調べる手がかりになります。

DecodingErrorにはいくつかの種類があり、それぞれ異なる原因を示しています。初心者のうちは難しく感じるかもしれませんが、エラーメッセージを見ればヒントが隠されています。

3. DecodingErrorの種類と原因

3. DecodingErrorの種類と原因
3. DecodingErrorの種類と原因

代表的なDecodingErrorの種類を順番に見ていきましょう。

3-1. typeMismatch(型の不一致)

JSONの値の型と、Swiftのプロパティの型が一致しないときに発生します。


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

let json = """
{
    "id": "abc",
    "name": "Taro"
}
""".data(using: .utf8)!

do {
    let user = try JSONDecoder().decode(User.self, from: json)
    print(user)
} catch {
    print(error)
}

typeMismatch(Swift.Int, ...)

この例では、本来数字であるべきidに文字列が入っているためエラーになっています。

3-2. keyNotFound(キーが見つからない)

JSONに必要なキーが存在しない場合に発生します。


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

let json = """
{
    "id": 1
}
""".data(using: .utf8)!

do {
    let user = try JSONDecoder().decode(User.self, from: json)
    print(user)
} catch {
    print(error)
}

keyNotFound(CodingKeys(stringValue: "name", intValue: nil), ...)

この場合、JSONにnameが無いためエラーになります。

3-3. valueNotFound(値が見つからない)

キーはあるけれど値がnullなどで欠落しているときに発生します。

3-4. dataCorrupted(データの破損)

JSONそのものが正しくない形式のときに発生します。例えば、カンマの位置が間違っていたり、文字列のクォーテーションが抜けていたりするケースです。

4. エラーを回避する方法

4. エラーを回避する方法
4. エラーを回避する方法

それでは、初心者がよくつまずくエラーの対処法を紹介します。

  • Optional型を使う:値が無い可能性がある場合はString?Int?と定義しましょう。
  • キーの対応を明示する:CodingKeysを使ってJSONのキー名とSwiftのプロパティを対応付けることができます。
  • デフォルト値を設定する:デコードに失敗しそうな場合は、初期値を用意して安全に扱いましょう。

5. 実際のエラーメッセージの読み方

5. 実際のエラーメッセージの読み方
5. 実際のエラーメッセージの読み方

Swiftのエラーメッセージには「どのプロパティで」「どんな理由で」失敗したかが書かれています。初心者の方は英語の文章に戸惑うかもしれませんが、焦らずに「型の不一致」「キーが見つからない」といった部分に注目しましょう。

たとえばkeyNotFoundと出ていたら「そのキーがJSONに無いんだな」と考え、JSONを確認して修正すると理解が早まります。

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

Swift実践入門をAmazonで見る

※ Amazon広告リンク

6. まとめて覚えるポイント

6. まとめて覚えるポイント
6. まとめて覚えるポイント

SwiftのJSONデコード失敗は多くの場合、型の不一致キーの不足です。DecodingErrorを読み解けば原因がわかり、すぐに対処できます。初心者のうちはエラーを恐れずに、JSONとSwiftの型定義を一つずつ確認していきましょう。

関連セミナーのご案内

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
Swift
Swiftのnilとは?Optionalとの関係や初期化について初心者向けにやさしく解説!
New2
Go言語
Go言語のinit関数の役割と使い方!プログラム起動時の初期化処理
New3
Go言語
Go言語のマップの順序保証がない理由と扱い方の工夫をやさしく解説!初心者でもわかる基本知識
New4
Kotlin
Kotlinのforループの基本!範囲・配列・コレクションの繰り返し処理
人気記事
No.1
Java&Spring記事人気No1
Kotlin
Kotlinのsettings.gradleファイルを完全解説!初心者でもわかるプロジェクト設定の基本
No.2
Java&Spring記事人気No2
Go言語
Swiftの配列(Array)の使い方を完全ガイド!初心者でもわかるデータのまとめ方
No.3
Java&Spring記事人気No3
Go言語
Go言語のSQLインジェクション対策を完全解説!初心者でも安全なデータベース操作がわかる
No.4
Java&Spring記事人気No4
Go言語
Swiftの文字列操作を完全ガイド!初心者でもわかるStringの基本
No.5
Java&Spring記事人気No5
Swift
Swiftの高階関数map・filter・reduceを完全解説!初心者でもわかる配列操作の基本
No.6
Java&Spring記事人気No6
Kotlin
KotlinのRoomで複雑なクエリを使いこなす!初心者でもわかる応用テクニック
No.7
Java&Spring記事人気No7
Go言語
Go言語のgo installコマンドの役割とインストール先の仕組みを徹底解説!
No.8
Java&Spring記事人気No8
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方