Чтение в файле JSON с помощью Swift

206

Я действительно пытаюсь прочитать файл JSON в Swift, чтобы поиграть с ним. Большую часть двух дней я потратил на повторный поиск и пробовал разные методы, но пока не повезло, поэтому я подписался на StackOverFlow, чтобы узнать, сможет ли кто-нибудь указать мне правильное направление .....

Мой JSON-файл называется test.json и содержит следующее:

{
  "person":[
     {
       "name": "Bob",
       "age": "16",
       "employed": "No"
     },
     {
       "name": "Vinny",
       "age": "56",
       "employed": "Yes"
     }
  ]
}    

Файл хранится в документах напрямую, и я обращаюсь к нему, используя следующий код:

let file = "test.json"
let dirs : String[] = NSSearchPathForDirectoriesInDomains(
                                                          NSSearchpathDirectory.DocumentDirectory,
                                                          NSSearchPathDomainMask.AllDomainMask,
                                                          true) as String[]

if (dirs != nil) {
    let directories: String[] = dirs
    let dir = directories[0]
    let path = dir.stringByAppendingPathComponent(file)
}

var jsonData = NSData(contentsOfFile:path, options: nil, error: nil)
println("jsonData \(jsonData)" // This prints what looks to be JSON encoded data.

var jsonDict = NSJSONSerialization.JSONObjectWithData(jsonData, options: nil, error: nil) as? NSDictionary

println("jsonDict \(jsonDict)") - This prints nil..... 

Если кто-то может просто дать мне толчок в правильном направлении, как я могу десериализовать файл JSON и поместить его в доступный объект Swift, я буду вечно благодарен!

С уважением,

Krivvenz.

Krivvenz
источник
1
используйте параметр ошибки ...
Matthias Bauch
2
Пожалуйста, отправьте актуальный, скомпилированный код. Как и сейчас, pathон виден только в ifобласти видимости и не разрешен при его использовании в NSData(contentsOfFile, options, error); у вас также есть опечатки в именах enum.
Крейри
1
Мой API полностью обновлен для Swift 3: github.com/borchero/WebParsing
borchero
это ключ -> «значения»: «% LOAD VALUE FROM tmclass.json file%», и мне нужно проанализировать другой JSON из файла, тогда как я могу добиться этого в SWIFT?
Mayur Shinde

Ответы:

288

Следуйте приведенному ниже коду:

if let path = NSBundle.mainBundle().pathForResource("test", ofType: "json")
{
    if let jsonData = NSData(contentsOfFile: path, options: .DataReadingMappedIfSafe, error: nil)
    {
        if let jsonResult: NSDictionary = NSJSONSerialization.JSONObjectWithData(jsonData, options: NSJSONReadingOptions.MutableContainers, error: nil) as? NSDictionary
        {
            if let persons : NSArray = jsonResult["person"] as? NSArray
            {
                // Do stuff
            }
        }
     }
}

Массив "people" будет содержать все данные для ключевого лица. Итерируйте проходы, чтобы получить его.

Swift 4.0:

if let path = Bundle.main.path(forResource: "test", ofType: "json") {
    do {
          let data = try Data(contentsOf: URL(fileURLWithPath: path), options: .mappedIfSafe)
          let jsonResult = try JSONSerialization.jsonObject(with: data, options: .mutableLeaves)
          if let jsonResult = jsonResult as? Dictionary<String, AnyObject>, let person = jsonResult["person"] as? [Any] {
                    // do stuff
          }
      } catch {
           // handle error
      }
}
Абхишек
источник
4
Было бы более полезно, если бы вы объяснили, почему / как это решает проблему, описанную в вопросе, вместо того, чтобы просто представлять кучу кода.
Мартин Р
Привет Абхишек - Спасибо за ваш ответ, но он все еще не работает. Это приводит к аварийному завершению работы приложения со следующей ошибкой: 2014-06-25 16: 02: 04.146 H & S Capture [4937: 131932] *** Завершение работы приложения из-за необработанного исключения «NSInvalidArgumentException», причина: «*** - [_NSPlaceholderData initWithContentsOfFile: параметры: ошибка:]: аргумент нулевого файла '*** Стек вызовов первого выброса: есть идеи, почему это так? Для параметров jsonData: я поставил (путь, параметры: NSDataReadingOptions.DataReadingMappedIfSafe, ошибка: ноль)
Криввенц
Ваш путь к файлу неверен. На самом деле, по указанному вами пути нет файла с именем test.json. Пожалуйста, проверьте правильность расположения файла
Abhishek
15
«let jsonData = NSData (contentsOfFile: путь!)» вместо «let jsonData = NSData.dataWithContentsOfFile (путь, опции: .DataReadingMappedIfSafe, ошибка: ноль)»
тонг
7
Здесь лучше использовать защитные операторы, а не пирамиду гибели.
Зонили Джейм
140

Если кто-то ищет SwiftyJSON Ответ:
Обновление:
Для Swift 3/4:

if let path = Bundle.main.path(forResource: "assets/test", ofType: "json") {
    do {
        let data = try Data(contentsOf: URL(fileURLWithPath: path), options: .alwaysMapped)
        let jsonObj = try JSON(data: data)
        print("jsonData:\(jsonObj)")
    } catch let error {
        print("parse error: \(error.localizedDescription)")
    }
} else {
    print("Invalid filename/path.")
}
Акс
источник
2
это превратило меня в swiftyJSON и Карфаген! спасибо :)
Пол Ванд
я использовал его только для того, чтобы обнаружить, что в нем отсутствует сопоставление объектов, в следующий раз я попробую другую библиотеку
Elazaron
Чтобы избежать ошибки вставки копии в swift 3: NSData и NSError стали Data and Error.
Сельва
Я попробовал несколько разных методов, и это сработало для меня лучше всего в Swift 3
crobicha
(!) Так как MacOS 10.6 / IOS 4 есть API url(forResourceв , (NS)Bundleчтобы избежать дополнительного шага , чтобы создать URL
vadian
102

Swift 4 с использованием Decodable

struct ResponseData: Decodable {
    var person: [Person]
}
struct Person : Decodable {
    var name: String
    var age: String
    var employed: String
}

func loadJson(filename fileName: String) -> [Person]? {
    if let url = Bundle.main.url(forResource: fileName, withExtension: "json") {
        do {
            let data = try Data(contentsOf: url)
            let decoder = JSONDecoder()
            let jsonData = try decoder.decode(ResponseData.self, from: data)
            return jsonData.person
        } catch {
            print("error:\(error)")
        }
    }
    return nil
}

Свифт 3

func loadJson(filename fileName: String) -> [String: AnyObject]? {
    if let url = Bundle.main.url(forResource: fileName, withExtension: "json") {
        do {
            let data = try Data(contentsOf: url)
            let object = try JSONSerialization.jsonObject(with: data, options: .allowFragments)
            if let dictionary = object as? [String: AnyObject] {
                return dictionary
            }
        } catch {
            print("Error!! Unable to parse  \(fileName).json")
        }
    }
    return nil
}
yarlg
источник
9
Это должно быть перенесено в новую функцию документации или помечено как правильный ответ.
система
24

Xcode 8 Swift 3 считывает json из обновления файла:

    if let path = Bundle.main.path(forResource: "userDatabseFakeData", ofType: "json") {
        do {
            let jsonData = try NSData(contentsOfFile: path, options: NSData.ReadingOptions.mappedIfSafe)
            do {
                let jsonResult: NSDictionary = try JSONSerialization.jsonObject(with: jsonData as Data, options: JSONSerialization.ReadingOptions.mutableContainers) as! NSDictionary
                if let people : [NSDictionary] = jsonResult["person"] as? [NSDictionary] {
                    for person: NSDictionary in people {
                        for (name,value) in person {
                            print("\(name) , \(value)")
                        }
                    }
                }
            } catch {}
        } catch {}
    }
Бен
источник
14

Обновлены названия для Swift 3.0

На основании ответа Абхишека и Друвы

func loadJson(forFilename fileName: String) -> NSDictionary? {

    if let url = Bundle.main.url(forResource: fileName, withExtension: "json") {
        if let data = NSData(contentsOf: url) {
            do {
                let dictionary = try JSONSerialization.jsonObject(with: data as Data, options: .allowFragments) as? NSDictionary

                return dictionary
            } catch {
                print("Error!! Unable to parse  \(fileName).json")
            }
        }
        print("Error!! Unable to load  \(fileName).json")
    }

    return nil
}
Ник Грэм
источник
12

Упрощение примера, представленного Питером Крейнцем. Работает со Swift 4.2.

Функция расширения:

extension Decodable {
  static func parse(jsonFile: String) -> Self? {
    guard let url = Bundle.main.url(forResource: jsonFile, withExtension: "json"),
          let data = try? Data(contentsOf: url),
          let output = try? JSONDecoder().decode(self, from: data)
        else {
      return nil
    }

    return output
  }
}

Пример модели:

struct Service: Decodable {
  let name: String
}

Пример использования:

/// service.json
/// { "name": "Home & Garden" }

guard let output = Service.parse(jsonFile: "service") else {
// do something if parsing failed
 return
}

// use output if all good

Пример будет работать и с массивами:

/// services.json
/// [ { "name": "Home & Garden" } ]

guard let output = [Service].parse(jsonFile: "services") else {
// do something if parsing failed
 return
}

// use output if all good

Обратите внимание, что мы не предоставляем ненужных обобщений, поэтому нам не нужно приводить результат разбора.

NeverwinterMoon
источник
10

Ответ Swift 2.1 (на основе ответов Абхишека):

    if let path = NSBundle.mainBundle().pathForResource("test", ofType: "json") {
        do {
            let jsonData = try NSData(contentsOfFile: path, options: NSDataReadingOptions.DataReadingMappedIfSafe)
            do {
                let jsonResult: NSDictionary = try NSJSONSerialization.JSONObjectWithData(jsonData, options: NSJSONReadingOptions.MutableContainers) as! NSDictionary
                if let people : [NSDictionary] = jsonResult["person"] as? [NSDictionary] {
                    for person: NSDictionary in people {
                        for (name,value) in person {
                            print("\(name) , \(value)")
                        }
                    }
                }
            } catch {}
        } catch {}
    }
KJM
источник
10

Swift 3.0, Xcode 8, iOS 10

 if let path = Bundle.main.url(forResource: "person", withExtension: "json") {

        do {
            let jsonData = try Data(contentsOf: path, options: .mappedIfSafe)
            do {
                if let jsonResult = try JSONSerialization.jsonObject(with: jsonData, options: JSONSerialization.ReadingOptions(rawValue: 0)) as? NSDictionary {
                    if let personArray = jsonResult.value(forKey: "person") as? NSArray {
                        for (_, element) in personArray.enumerated() {
                            if let element = element as? NSDictionary {
                                let name = element.value(forKey: "name") as! String
                                let age = element.value(forKey: "age") as! String
                                let employed = element.value(forKey: "employed") as! String
                                print("Name: \(name),  age: \(age), employed: \(employed)")
                            }
                        }
                    }
                }
            } catch let error as NSError {
                print("Error: \(error)")
            }
        } catch let error as NSError {
            print("Error: \(error)")
        }
    }

Вывод:

Name: Bob,  age: 16, employed: No
Name: Vinny,  age: 56, employed: Yes
Ашок Р
источник
7

Это прекрасно сработало со мной

func readjson(fileName: String) -> NSData{

    let path = NSBundle.mainBundle().pathForResource(fileName, ofType: "json")
    let jsonData = NSData(contentsOfMappedFile: path!)

    return jsonData!
}
Абдулазиз Нур
источник
7

Вот мое решение с использованием SwiftyJSON

if let path : String = NSBundle.mainBundle().pathForResource("filename", ofType: "json") {
    if let data = NSData(contentsOfFile: path) {

        let json = JSON(data: data)

    }
}
will.fiset
источник
7
fileprivate class BundleTargetingClass {}
func loadJSON<T>(name: String) -> T? {
  guard let filePath = Bundle(for: BundleTargetingClass.self).url(forResource: name, withExtension: "json") else {
    return nil
  }

  guard let jsonData = try? Data(contentsOf: filePath, options: .mappedIfSafe) else {
    return nil
  }

  guard let json = try? JSONSerialization.jsonObject(with: jsonData, options: .allowFragments) else {
    return nil
  }

  return json as? T
}

👆🏻 готово к копированию и вставке, независимое от сторонних разработчиков решение.

использование 👇🏻

let json:[[String : AnyObject]] = loadJSON(name: "Stations")!

Мацей Банасевич
источник
это сработало для меня. Мне нужно было жестко закодировать список доступных для поиска лекарств в приложение. Я получил файл JSON из базы данных MySQL. Я поместил файл json в мой проект XCODE, запущенный выше в viewDidLoad, и я получил свой словарь json !!!
Брайан
5

Я даю другой ответ, потому что ни один из них не предназначен для загрузки ресурса из тестового пакета. Если вы используете удаленный сервис, который использует JSON и хотите выполнить модульное тестирование, анализируя результаты, не затрагивая реальный сервис, вы берете один или несколько ответов и помещаете их в файлы в папке «Тесты» в своем проекте.

func testCanReadTestJSONFile() {
    let path = NSBundle(forClass: ForecastIOAdapterTests.self).pathForResource("ForecastIOSample", ofType: "json")
    if let jsonData = NSData(contentsOfFile:path!) {
        let json = JSON(data: jsonData)
        if let currentTemperature = json["currently"]["temperature"].double {
            println("json: \(json)")
            XCTAssertGreaterThan(currentTemperature, 0)
        }
    }
}

При этом также используется SwiftyJSON, но основная логика получения тестового пакета и загрузки файла - ответ на вопрос.

обкрадывать
источник
5

Swift 4: опробуйте мое решение:

test.json

{
    "person":[
        {
            "name": "Bob",
            "age": "16",
            "employed": "No"
        },
        {
            "name": "Vinny",
            "age": "56",
            "employed": "Yes"
        }
    ]
}

RequestCodable.swift

import Foundation

struct RequestCodable:Codable {
    let person:[PersonCodable]
}

PersonCodable.swift

import Foundation

struct PersonCodable:Codable {
    let name:String
    let age:String
    let employed:String
}

Декодируемый + FromJSON.swift

import Foundation

extension Decodable {

    static func fromJSON<T:Decodable>(_ fileName: String, fileExtension: String="json", bundle: Bundle = .main) throws -> T {
        guard let url = bundle.url(forResource: fileName, withExtension: fileExtension) else {
            throw NSError(domain: NSURLErrorDomain, code: NSURLErrorResourceUnavailable)
        }

        let data = try Data(contentsOf: url)

        return try JSONDecoder().decode(T.self, from: data)
    }
}

Пример:

let result = RequestCodable.fromJSON("test") as RequestCodable?

result?.person.compactMap({ print($0) }) 

/*
PersonCodable(name: "Bob", age: "16", employed: "No")
PersonCodable(name: "Vinny", age: "56", employed: "Yes")
*/
Питер Крейнз
источник
1
Ваша fromJSONфункция расширения выбрасывает, но в примере вы вызываете ее без tryключевого слова. Этот код не будет компилироваться.
NeverwinterMoon
Кроме того, fromJSONвы используете расширение Decodable, но при этом вы не используете информацию типа Decodable, а предоставляете дополнительные (совершенно бесполезные) обобщения.
NeverwinterMoon
3

Последний swift 3.0 абсолютно рабочий

func loadJson(filename fileName: String) -> [String: AnyObject]?
{
    if let url = Bundle.main.url(forResource: fileName, withExtension: "json") 
{
      if let data = NSData(contentsOf: url) {
          do {
                    let object = try JSONSerialization.jsonObject(with: data as Data, options: .allowFragments)
                    if let dictionary = object as? [String: AnyObject] {
                        return dictionary
                    }
                } catch {
                    print("Error!! Unable to parse  \(fileName).json")
                }
            }
            print("Error!! Unable to load  \(fileName).json")
        }
        return nil
    }
Khushboo
источник
3

Swift 4 JSONto Classwith Decodable- для тех, кто предпочитает занятия

Определите классы следующим образом:

class People: Decodable {
  var person: [Person]?

  init(fileName : String){
    // url, data and jsonData should not be nil
    guard let url = Bundle.main.url(forResource: fileName, withExtension: "json") else { return }
    guard let data = try? Data(contentsOf: url) else { return }
    guard let jsonData = try? JSONDecoder().decode(People.self, from: data) else { return }

    // assigns the value to [person]
    person = jsonData.person
  }
}

class Person : Decodable {
  var name: String
  var age: String
  var employed: String
}

Использование, довольно абстрактно:

let people = People(fileName: "people")
let personArray = people.person

Это позволяет методы как для классов, так Peopleи для Personпеременных, атрибутов и методов также могут быть помечены, как privateэто необходимо.

Марко Леонг
источник
3

Следующий код работает для меня. Я использую Swift 5

let path = Bundle.main.path(forResource: "yourJSONfileName", ofType: "json")
var jsonData = try! String(contentsOfFile: path!).data(using: .utf8)!

Затем, если ваш Person Struct (или Class) является Decodable (а также все его свойства), вы можете просто сделать:

let person = try! JSONDecoder().decode(Person.self, from: jsonData)

Я избегал всего кода обработки ошибок, чтобы сделать код более разборчивым.

Авраам Симпсон
источник
2

Обновлено для Swift 3 с самым безопасным способом

    private func readLocalJsonFile() {

    if let urlPath = Bundle.main.url(forResource: "test", withExtension: "json") {

        do {
            let jsonData = try Data(contentsOf: urlPath, options: .mappedIfSafe)

            if let jsonDict = try JSONSerialization.jsonObject(with: jsonData, options: .mutableContainers) as? [String: AnyObject] {

                if let personArray = jsonDict["person"] as? [[String: AnyObject]] {

                    for personDict in personArray {

                        for (key, value) in personDict {

                            print(key, value)
                        }
                        print("\n")
                    }
                }
            }
        }

        catch let jsonError {
            print(jsonError)
        }
    }
}

введите описание изображения здесь

IAJ
источник
2

Swift 5.1, Xcode 11

Вы можете использовать это:


struct Person : Codable {
    let name: String
    let lastName: String
    let age: Int
}

func loadJson(fileName: String) -> Person? {
   let decoder = JSONDecoder()
   guard
        let url = Bundle.main.url(forResource: fileName, withExtension: "json"),
        let data = try? Data(contentsOf: url),
        let person = try? decoder.decode(Person.self, from: data)
   else {
        return nil
   }

   return person
}
Gonzer
источник
1

Исходя из ответа Абхишека , для iOS 8 это будет:

let masterDataUrl: NSURL = NSBundle.mainBundle().URLForResource("masterdata", withExtension: "json")!
let jsonData: NSData = NSData(contentsOfURL: masterDataUrl)!
let jsonResult: NSDictionary = NSJSONSerialization.JSONObjectWithData(jsonData, options: nil, error: nil) as! NSDictionary
var persons : NSArray = jsonResult["person"] as! NSArray
Дэвид Поксон
источник
Вы используете Swift 2.0? Тогда да, это было бы так. На это ответили до-2.0.
Дэвид Поксон
1

Это работало для меня с XCode 8.3.3

func fetchPersons(){

    if let pathURL = Bundle.main.url(forResource: "Person", withExtension: "json"){

        do {

            let jsonData = try Data(contentsOf: pathURL, options: .mappedIfSafe)

            let jsonResult = try JSONSerialization.jsonObject(with: jsonData, options: .mutableContainers) as! [String: Any]
            if let persons = jsonResult["person"] as? [Any]{

                print(persons)
            }

        }catch(let error){
            print (error.localizedDescription)
        }
    }
}
anoop4real
источник
1

Swift 4.1 обновил Xcode 9.2

if let filePath = Bundle.main.path(forResource: "fileName", ofType: "json"), let data = NSData(contentsOfFile: filePath) {

     do {
      let json = try JSONSerialization.jsonObject(with: data as Data, options: JSONSerialization.ReadingOptions.allowFragments)        
        }
     catch {
                //Handle error
           }
 }
Saranjith
источник
3
В этом нет ничего нового, скорее наоборот: не используйте NSDataв Swift 3+, и .allowFragmentsв этом случае это бессмысленно.
vadian
1
//change type based on your struct and right JSON file

let quoteData: [DataType] =
    load("file.json")

func load<T: Decodable>(_ filename: String, as type: T.Type = T.self) -> T {
    let data: Data

    guard let file = Bundle.main.url(forResource: filename, withExtension: nil)
        else {
            fatalError("Couldn't find \(filename) in main bundle.")
    }

    do {
        data = try Data(contentsOf: file)
    } catch {
        fatalError("Couldn't load \(filename) from main bundle:\n\(error)")
    }

    do {
        let decoder = JSONDecoder()
        return try decoder.decode(T.self, from: data)
    } catch {
        fatalError("Couldn't parse \(filename) as \(T.self):\n\(error)")
    }
}

ASHISH RANJAN
источник
0

Я использовал приведенный ниже код для извлечения JSON из файла FAQ-data.json, присутствующего в каталоге проекта.

Я реализую в Xcode 7.3, используя Swift.

     func fetchJSONContent() {
            if let path = NSBundle.mainBundle().pathForResource("FAQ-data", ofType: "json") {

                if let jsonData = NSData(contentsOfFile: path) {
                    do {
                        if let jsonResult: NSDictionary = try NSJSONSerialization.JSONObjectWithData(jsonData, options: NSJSONReadingOptions.MutableContainers) as? NSDictionary {

                            if let responseParameter : NSDictionary = jsonResult["responseParameter"] as? NSDictionary {

                                if let response : NSArray = responseParameter["FAQ"] as? NSArray {
                                    responseFAQ = response
                                    print("response FAQ : \(response)")
                                }
                            }
                        }
                    }
                    catch { print("Error while parsing: \(error)") }
                }
            }
        }

override func viewWillAppear(animated: Bool) {
        fetchFAQContent()
    }

Структура файла JSON:

{
    "status": "00",
    "msg": "FAQ List ",
    "responseParameter": {
        "FAQ": [
            {                
                "question":Question No.1 here”,
                "answer":Answer goes here”,  
                "id": 1
            },
            {                
                "question":Question No.2 here”,
                "answer":Answer goes here”,
                "id": 2
            }
            . . .
        ]
    }
}
Джайпракаш Дубей
источник
0

Я также мог бы порекомендовать Ray Wenderlich Swift JSON Tutorial (который также охватывает удивительную альтернативу SwiftyJSON, Gloss ). Выдержка (которая предоставлена ​​сама по себе, не полностью отвечает автору, но добавленная ценность этого ответа - ссылка, поэтому для этого не нужно использовать -1):

В Objective-C анализ и десериализация JSON довольно просты:

NSArray *json = [NSJSONSerialization JSONObjectWithData:JSONData
options:kNilOptions error:nil];
NSString *age = json[0][@"person"][@"age"];
NSLog(@"Dani's age is %@", age);

В Swift анализ и десериализация JSON немного более утомительны из-за опций Swift и безопасности типов [но как часть] Swift 2.0, guardоператор был введен, чтобы помочь избавиться от вложенных ifоператоров:

var json: Array!
do {
  json = try NSJSONSerialization.JSONObjectWithData(JSONData, options: NSJSONReadingOptions()) as? Array
} catch {
  print(error)
}

guard let item = json[0] as? [String: AnyObject],
  let person = item["person"] as? [String: AnyObject],
  let age = person["age"] as? Int else {
    return;
}
print("Dani's age is \(age)")

Конечно, в XCode 8.x вы просто дважды нажимаете пробел и говорите: «Эй, Сири, пожалуйста, десериализуйте этот JSON для меня в Swift 3.0 с пробелами / табуляциями».

AmitaiB
источник
0

SWIFTYJSON ВЕРСИЯ SWIFT 3

func loadJson(fileName: String) -> JSON {

    var dataPath:JSON!

    if let path : String = Bundle.main.path(forResource: fileName, ofType: "json") {
        if let data = NSData(contentsOfFile: path) {
             dataPath = JSON(data: data as Data)
        }
    }
    return dataPath
}
Ахмед Сафади
источник
0

Сначала создайте кодируемый Struc следующим образом:

  struct JuzgadosList : Codable {
    var CP : Int
    var TEL : String
    var LOCAL : String
    var ORGANO : String
    var DIR : String
}

Теперь объявите переменную

 var jzdosList = [JuzgadosList]()

Читать из основного каталога

func getJsonFromDirectory() {

        if let path = Bundle.main.path(forResource: "juzgados", ofType: "json") {
            do {
                let data = try Data(contentsOf: URL(fileURLWithPath: path), options: .alwaysMapped)
                let jList = try JSONDecoder().decode([JuzgadosList].self, from: data)
                self.jzdosList = jList

                DispatchQueue.main.async() { () -> Void in
                    self.tableView.reloadData()
                }

            } catch let error {
                print("parse error: \(error.localizedDescription)")
            }
        } else {
            print("Invalid filename/path.")
        }
    }

Читать из Интернета

func getJsonFromUrl(){

        self.jzdosList.removeAll(keepingCapacity: false)

        print("Internet Connection Available!")

        guard let url = URL(string: "yourURL")  else { return }

        let request = URLRequest(url: url, cachePolicy: URLRequest.CachePolicy.reloadIgnoringLocalCacheData, timeoutInterval: 60.0)
        URLSession.shared.dataTask(with: request) { (data, response, err) in
            guard let data = data else { return }
            do {
                let jList = try JSONDecoder().decode([JuzgadosList].self, from: data)
                self.jzdosList = jList

                DispatchQueue.main.async() { () -> Void in
                    self.tableView.reloadData()
                }
            } catch let jsonErr {
                print("Error serializing json:", jsonErr)
            }
        }.resume()
    }
Оскар Кастельон
источник
0

Используйте эту универсальную функцию

func readJSONFromFile<T: Decodable>(fileName: String, type: T.Type) -> T? {
    if let url = Bundle.main.url(forResource: fileName, withExtension: "json") {
        do {
            let data = try Data(contentsOf: url)
            let decoder = JSONDecoder()
            let jsonData = try decoder.decode(T.self, from: data)
            return jsonData
        } catch {
            print("error:\(error)")
        }
    }
    return nil
}

с этой строкой кода:

let model = readJSONFromFile(fileName: "Model", type: Model.self)

для этого типа:

struct Model: Codable {
    let tall: Int
}
Халед Аннажар
источник