質問編集履歴

2 ソースコードにコメントを追加しました

kusukusu

kusukusu score 20

2018/06/09 17:28  投稿

URLSessionの処理が完了したタイミングでcollectionViewメソッドを呼んでほしい
URLSessionを使って、HTMLデータを取得し、画像データだけを抜き出して
matchStrings[String]変数に代入します。
その配列の数だけCollectionViewのCellを生成したいのですが、matchStrings配列に値が入る前にCollectionViewメソッドが呼ばれて、Cell数が決定してしまい、うまくいきません。
自分なりに解決策を調べて見たのですが、良い方法がなかなか見つからず、頼らせていただくことにしました。
ぜひ皆様のアドバイスをいただきたく思います。
よろしくお願いします。
以下ソースコード
```Swift
import UIKit
class ViewController: UICollectionViewController {
 
 var matchStrings:[String] = []
 
 override func viewDidLoad() {
   super.viewDidLoad()
   
   let url = URL(string: "http://moeimg.net/11414.html")
   
   let task = URLSession.shared.dataTask(with: URLRequest(url: url!), completionHandler: { (data, response, error) in
     if error != nil {
       print(error!.localizedDescription)
     } else {
       let json: String = NSString(data:data!,encoding:String.Encoding.utf8.rawValue)! as String
//       let pattern = "src=\"(.+?)\""
//       let pattern = "http://.+?\\.jpg\""
       let pattern = "http\\\"?([\\-_\\.\\!\\~\\*\\'\\(\\)a-z0-9\\;\\/\\?\\:@&=\\+\\$\\,\\%\\#]+(jpg|jpeg|gif|png|bmp))"
//       print(pattern)
       self.matchStrings = self.getMatchStrings(targetString: json, pattern: pattern)
       for str in self.matchStrings {
         print(str)
       }
//       print(json)
     }
   })
   task.resume()
   
 }
 
 
 func getMatchStrings(targetString: String, pattern: String) -> [String] {
   
   var matchStrings:[String] = []
   
   do {
     
     let regex = try NSRegularExpression(pattern: pattern, options: [])
     let targetStringRange = NSRange(location: 0, length: (targetString as NSString).length)
     
     let matches = regex.matches(in: targetString, options: [], range: targetStringRange)
     
     for match in matches {
       
       let range = match.range(at: 0)
       let result = (targetString as NSString).substring(with: range)
       
       matchStrings.append(result)
     }
     
     return matchStrings
     
   } catch {
     print("error: getMatchStrings")
   }
   return []
 }
 override func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
 
   return 1
   return matchStrings.count //この時点ではまだ配列に要素が入っておらずcountは0になっており、うまくいかない
 }
 
 override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
   let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "Cell", for: indexPath) as! CollectionViewCell
   let url = URL(string: "http://img-cdn.jg.jugem.jp/584/719314/20170330_2059308.png")
   
   DispatchQueue.global().async {
     let data = try? Data(contentsOf: url!)
     DispatchQueue.main.async {
       cell.imageView.image = UIImage(data: data!)
     }
   }
   return cell
 }
}
```
  • Swift

    8935 questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

1 誤字脱字があったため編集しました。

kusukusu

kusukusu score 20

2018/06/09 17:24  投稿

URLSessionの処理が完了したタイミングでcollectionViewメソッドを呼んでほしい
URLSessionを使って、HTMLデータを取得し、画像データだけを抜き出して
matchStrings[String]変数に代入します。
その配列の数ぶんCollectionViewのCellを生成したいのですが、matchStrings配列に値が入る前にCollectionView
その配列の数だけCollectionViewのCellを生成したいのですが、matchStrings配列に値が入る前にCollectionViewメソッドが呼ばれて、Cell数が決定してしまい、うまくいきません。
自分なりに解決策を調べて見たのですが、良い方法がなかなか見つからず、頼らせていただくことにしました。
ぜひ皆様のアドバイスをいただきたく思います。
よろしくお願いします。
以下ソースコード
```Swift
import UIKit
class ViewController: UICollectionViewController {
 
 var matchStrings:[String] = []
 
 override func viewDidLoad() {
   super.viewDidLoad()
   
   let url = URL(string: "http://moeimg.net/11414.html")
   
   let task = URLSession.shared.dataTask(with: URLRequest(url: url!), completionHandler: { (data, response, error) in
     if error != nil {
       print(error!.localizedDescription)
     } else {
       let json: String = NSString(data:data!,encoding:String.Encoding.utf8.rawValue)! as String
//       let pattern = "src=\"(.+?)\""
//       let pattern = "http://.+?\\.jpg\""
       let pattern = "http\\\"?([\\-_\\.\\!\\~\\*\\'\\(\\)a-z0-9\\;\\/\\?\\:@&=\\+\\$\\,\\%\\#]+(jpg|jpeg|gif|png|bmp))"
//       print(pattern)
       self.matchStrings = self.getMatchStrings(targetString: json, pattern: pattern)
       for str in self.matchStrings {
         print(str)
       }
//       print(json)
     }
   })
   task.resume()
   
 }
 
 
 func getMatchStrings(targetString: String, pattern: String) -> [String] {
   
   var matchStrings:[String] = []
   
   do {
     
     let regex = try NSRegularExpression(pattern: pattern, options: [])
     let targetStringRange = NSRange(location: 0, length: (targetString as NSString).length)
     
     let matches = regex.matches(in: targetString, options: [], range: targetStringRange)
     
     for match in matches {
       
       let range = match.range(at: 0)
       let result = (targetString as NSString).substring(with: range)
       
       matchStrings.append(result)
     }
     
     return matchStrings
     
   } catch {
     print("error: getMatchStrings")
   }
   return []
 }
 override func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
 
   return 1
 }
 
 override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
   let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "Cell", for: indexPath) as! CollectionViewCell
   let url = URL(string: "http://img-cdn.jg.jugem.jp/584/719314/20170330_2059308.png")
   
   DispatchQueue.global().async {
     let data = try? Data(contentsOf: url!)
     DispatchQueue.main.async {
       cell.imageView.image = UIImage(data: data!)
     }
   }
   return cell
 }
}
```
  • Swift

    8935 questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

思考するエンジニアのためのQ&Aサイト「teratail」について詳しく知る