2017-10-17 14 views
0
override func viewDidLoad() { 
    super.viewDidLoad() 
    DispatchQueue.global().async(execute: { 
     print("teste") 
      print("main thread") 
      self.getWeather(city: "Minsk") 
     print("Hello") 

    }) 
    print("working") 
} 

func getWeather(city: String) { 

    let cityEscaped = city.addingPercentEncoding(withAllowedCharacters: CharacterSet.urlHostAllowed) 

    let path = "http://samples.openweathermap.org/data/2.5/weather?q=Minsk&appid=..." // appid removed for the sake of privacy 
    let url = URL(string: path) 
    let session = URLSession.shared 

    let task = session.dataTask(with: url!) { (data: Data?, response: URLResponse?, error: Error?) in 
     let json = JSON(data!) 
     let lon = json["coord"]["lon"].double 
     let lat = json["coord"]["lat"].double 
     let temp = json["main"]["temp"].double 
     let name = json["name"].string 
     let desc = json["weather"][0]["description"].string 

     print("Lat: \(lat!) lon:\(lon!) temp: \(temp!) city: \(name!)") 
    } 

    task.resume() 
} 

は、印刷ラインもたらした( "緯度:!(緯度)経度:!(ロン)一時:!(Temp)に市:!(名)")そして、コードの継続的な実行後?DispatchQueue.main.sync迅速

+3

は、あなたの質問を翻訳... –

+0

あなたがそれをダウンロードする最初の印刷結果にしたいですか? 「こんにちは」「緯度経度」の後に持ち込まする –

+0

はどういう意味ですか? –

答えて

1

あなたはgetWeatherが行われた後に何かをしたい場合は、完了ハンドラを追加します。個人的に、Iキャプチャされた情報をバック渡す構造を作成することによって、これを簡略化したい:

struct WeatherReport { 
    let latitude: Double 
    let longitude: Double 
    let temperature: Double 
    let name: String 
    let desc: String 
} 

func getWeather(city: String, completion: @escaping (WeatherReport?, Error?) -> Void) { 

    ... 

    let task = session.dataTask(with: url!) { data, _, error in 
     ... 
     guard successful else { 
      completion(nil, error) 
      return 
     } 

     let weatherReport = WeatherReport(...) 
     completion(weatherReport, nil) 
    } 

    task.resume() 
} 

そして

override func viewDidLoad() { 
    super.viewDidLoad() 

    getWeather(city: "Minsk") { weatherReport, error in 
     guard let weatherReport = weatherReport, error == nil else { 
      print(error?.localizedDescription ?? "Unknown error") 
      return 
     } 

     DispatchQueue.main.async { 
      // do something with `weatherReport` here 
     } 
    } 
} 

注、dataTaskは既に(a)は、非同期的に実行されます。および(b)は上図のようなので、viewDidLoadは、明示的にモデルオブジェクトおよび/またはgetWeather完了ハンドラでメインキューにUIでない何かを派遣する必要があり、バックグラウンドスレッドでその完了ハンドラを実行します。ところで


あなたはスウィフト4を使用している場合、私はその第三者JSONの構文解析ライブラリを排除し、JSONDecoderを使用することをお勧めしてDecodableあるモデル構造、例えばしたい:

struct Coordinate: Decodable { 
    let latitude: Double 
    let longitude: Double 

    enum CodingKeys: String, CodingKey { 
     case latitude = "lat" 
     case longitude = "lon" 
    } 
} 

struct WeatherReportDetails: Decodable { 
    let temperature: Double 
    let pressure: Double 
    let humidity: Double 
    let temperatureMin: Double 
    let temperatureMax: Double 

    enum CodingKeys: String, CodingKey { 
     case pressure, humidity 
     case temperature = "temp" 
     case temperatureMin = "temp_min" 
     case temperatureMax = "temp_max" 
    } 
} 

struct WeatherReport: Decodable { 
    let coordinate: Coordinate 
    let details: WeatherReportDetails 
    let name: String 

    enum CodingKeys: String, CodingKey { 
     case name 
     case coordinate = "coord" 
     case details = "main" 
    } 
} 

そして

func getWeather(city: String, completion: @escaping (WeatherReport?, Error?) -> Void) { 
    let cityEscaped = city.addingPercentEncoding(withAllowedCharacters: CharacterSet.urlHostAllowed)! 
    let urlString = "http://samples.openweathermap.org/data/2.5/weather?q=" + cityEscaped + "&appid=..." // appid removed for privacy’s sake 
    let url = URL(string: urlString)! 

    let task = URLSession.shared.dataTask(with: url) { data, _, error in 
     guard let data = data, error == nil else { 
      completion(nil, error) 
      return 
     } 

     do { 
      let weatherReport = try JSONDecoder().decode(WeatherReport.self, from: data) 
      completion(weatherReport, nil) 
     } catch { 
      completion(nil, error) 
     } 
    } 

    task.resume() 
} 
+0

@HeltyrCafryを求めることができます第三者JSONライブラリーとスウィフト4の新しい 'JSONDecoder'のAPIとた' Decodable'プロトコルを使用します。改訂された答えを参照してください。 – Rob

+0

おかげでしようとします(笑。無視して自由に感じる、スウィフト3を使用している場合。) –