class ViewController: UIViewController , UISearchBarDelegate { override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view. // Search Barのdelegate通知を設定 searchText.delegate = self // 入力のヒントとなる、プレースホルダーを設定 searchText.placeholder = "お菓子の名前を入力してください" } @IBOutlet weak var searchText: UISearchBar! @IBOutlet weak var tableView: UITableView! // お菓子のリスト(タップル配列) var okashiList : [(name:String , maker:String , link:URL , image:URL)] = [] // 検索ボタンをクリック (タップ) 時 func searchBarSearchButtonClicked(_ searchBar: UISearchBar) { // キーボードを閉じる view.endEditing(true) if let searchWord = searchBar.text { // デバックエリアに出力 print(searchWord) // 入力されていたら、お菓子を検索 searchOkashi(keyword: searchWord) } } //JSONのitem内のデータ構造 struct ItemJson: Codable { //お菓子の名称 let name: String? //掲載URL let url: URL? //画像URL let image: URL? } //JSONのデータ構造 struct ResultJson: Codable { //複数要素 let item:[ItemJson]? } // searchOkashiメゾット // 第一引数:keyword 検索したいワード func searchOkashi(keyword : String){ // お菓子の検索キーワードをURLエンコードする guard let keyword_encode = keyword.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else { return } // リクエストURLの組み立て guard let req_url = URL(string: "https://sysbird.jp/toriko/api/?apikey=guest&format=json&keyword=(keyword_encode)&max=10&order=r") else { return } print(req_url) // リクエストに必要な情報を生成 let req = URLRequest(url: req_url) // データ転送を管理するためのセッションを生成 let session = URLSession(configuration: .default, delegate: nil,delegateQueue: OperationQueue.main) // リクエストをタスクとして登録 let task = session.dataTask(with: req,completionHandler: { (sataa , response , error) in // セッションを終了 session.finishTasksAndInvalidate() // dotry catch エラーハンドリング do { // JSONDecoderのインスタンス取得 let decoder = JSONDecoder() // 受け取ったJSONデータをバース(解析)して格納 let json = try decoder.decode(ResultJson.self, from: data!)←ここです。 // お菓子の情報が取得できているか確認 if let items = json.item { // 取得しているお菓子の数だけ処理 for item in items { // お菓子の名所、メ−カー名、掲載URL、画像URL、をアンラップ if let name = item.name , let maker = intem.maker , let link = item.url , let image = item.image { // 1つのお菓子をダブルでまとめて管理 let okashi = (name,maker,link,image) // お菓子の配列へ追加 self.okashiList.append(okashi) } } if let okashidbg = self.okashiList.first { print ("----------------") print ("okashiList[0] = (okashidbg)") } } } catch { // エラー処理 print("エラーが出ました") } }) // ダウンロード開始 task.resume()```### 前提・実現したいこと class ViewController: UIViewController , UISearchBarDelegate { override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view. // Search Barのdelegate通知を設定 searchText.delegate = self // 入力のヒントとなる、プレースホルダーを設定 searchText.placeholder = "お菓子の名前を入力してください" } @IBOutlet weak var searchText: UISearchBar! @IBOutlet weak var tableView: UITableView! // お菓子のリスト(タップル配列) var okashiList : [(name:String , maker:String , link:URL , image:URL)] = [] // 検索ボタンをクリック (タップ) 時 func searchBarSearchButtonClicked(_ searchBar: UISearchBar) { // キーボードを閉じる view.endEditing(true) if let searchWord = searchBar.text { // デバックエリアに出力 print(searchWord) // 入力されていたら、お菓子を検索 searchOkashi(keyword: searchWord) } } //JSONのitem内のデータ構造 struct ItemJson: Codable { //お菓子の名称 let name: String? //掲載URL let url: URL? //画像URL let image: URL? } //JSONのデータ構造 struct ResultJson: Codable { //複数要素 let item:[ItemJson]? } // searchOkashiメゾット // 第一引数:keyword 検索したいワード func searchOkashi(keyword : String){ // お菓子の検索キーワードをURLエンコードする guard let keyword_encode = keyword.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else { return } // リクエストURLの組み立て guard let req_url = URL(string: "https://sysbird.jp/toriko/api/?apikey=guest&format=json&keyword=(keyword_encode)&max=10&order=r") else { return } print(req_url) // リクエストに必要な情報を生成 let req = URLRequest(url: req_url) // データ転送を管理するためのセッションを生成 let session = URLSession(configuration: .default, delegate: nil,delegateQueue: OperationQueue.main) // リクエストをタスクとして登録 let task = session.dataTask(with: req,completionHandler: { (sataa , response , error) in // セッションを終了 session.finishTasksAndInvalidate() // dotry catch エラーハンドリング do { // JSONDecoderのインスタンス取得 let decoder = JSONDecoder() // 受け取ったJSONデータをバース(解析)して格納 let json = try decoder.decode(ResultJson.self, from: data!)←ここです。 // お菓子の情報が取得できているか確認 if let items = json.item { // 取得しているお菓子の数だけ処理 for item in items { // お菓子の名所、メ−カー名、掲載URL、画像URL、をアンラップ if let name = item.name , let maker = intem.maker , let link = item.url , let image = item.image { // 1つのお菓子をダブルでまとめて管理 let okashi = (name,maker,link,image) // お菓子の配列へ追加 self.okashiList.append(okashi) } } if let okashidbg = self.okashiList.first { print ("----------------") print ("okashiList[0] = (okashidbg)") } } } catch { // エラー処理 print("エラーが出ました") } }) // ダウンロード開始 task.resume() ここの部分がエラーになります。↓ let json = try decoder.decode(ResultJson.self, from: data!)} } ### 発生している問題・エラーメッセージ
Cannot find 'data' in scope
### 該当のソースコード ```Swift
試したこと
うち間違えも何回も確認しました
初心者です
2日悩んでも解決出来なかったので詳しい方お願いします
ここに問題に対して試したことを記載してください。
補足情報(FW/ツールのバージョンなど)
Swift 5
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/03/02 17:40