如何在 Tableviewcontroller 中显示搜索结果?

How to display searched result in Tableviewcontroller?

我想在tableviewcontroller中显示搜索到的核心数据结果。我知道如何在 tableview 中显示核心数据,但我希望在 tableviewcontroller 中显示特定数据。

like,当用户select从uipickerview中获取特定的城市,然后根据特定的城市显示在tableviewcontroller中的核心数据结果。

下面列出了一些代码。

导入 UIKit 导入核心数据

class MenuhospitalTableViewController: UITableViewController {

private var hospitalcoredata: [Hospitalcoredata] = []
var fetchResultController:NSFetchedResultsController!

override func viewDidLoad() {
    super.viewDidLoad()

     Load menu items from database
    if let managedObjectContextt = (UIApplication.sharedApplication().delegate as! AppDelegate).managedObjectContextt {
        let fetchRequest = NSFetchRequest(entityName: "Hospitalcoredata")
        var e: NSError?
        hospitalcoredata = managedObjectContextt.executeFetchRequest(fetchRequest, error: &e) as! [Hospitalcoredata]
        if e != nil {
            println("Failed to retrieve record: \(e!.localizedDescription)")
        }
    }


    // Make the cell self size
    self.tableView.estimatedRowHeight = 66.0
    self.tableView.rowHeight = UITableViewAutomaticDimension
    self.tableView.layoutIfNeeded()
}

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}

// MARK: - Table view data source

override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
    // Return the number of sections.
    return 1
}



override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    // Return the number of rows in the section.
    return hospitalcoredata.count
}

override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as! MenuhospitalTableViewCell

    // Configure the cell...
    cell.nameLabel.text = hospitalcoredata[indexPath.row].namee
    cell.contactnoLabel.text = hospitalcoredata[indexPath.row].contactnoo
    //        cell.priceLabel.text = "$\(menuItems[indexPath.row].price as! Double)"

    return cell
}

/*
// MARK: - Navigation

// In a storyboard-based application, you will often want to do a little preparation before navigation
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
// Get the new view controller using [segue destinationViewController].
// Pass the selected object to the new view controller.
}
*/}

下面给出了从城市中查找数据的代码..

    let entityDescription =
    NSEntityDescription.entityForName("Register",
        inManagedObjectContext: managedObjectContext!)

    let request = NSFetchRequest()
    request.entity = entityDescription

    let pred = NSPredicate(format: "(name = %@)", name.text)
    request.predicate = pred

    var error: NSError?

    var objects = managedObjectContext?.executeFetchRequest(request,
        error: &error)

    if let results = objects {

        if results.count > 0 {
            let match = results[0] as! NSManagedObject

            name.text = match.valueForKey("name") as! String
            contactno.text = match.valueForKey("contactno") as! String
            altno.text = match.valueForKey("altno") as! String
            emailid.text = match.valueForKey("emailid") as! String
            textf.text = match.valueForKey("bloodgroup") as! String
            textff.text = match.valueForKey("city") as! String

            status.text = "Matches found: \(results.count)"
        } else {
            status.text = "No Match"
        }
    }
}

我想混合这两个代码并相应地显示核心数据结果 "city" selection。

您应该使用 NSFetchedResultsController 来填充您的 table 视图。在更新 table 视图之前,将动态谓词添加到其提取请求和 performFetch

在我的项目指南(chirag pandya 教授)的大量尝试和帮助之后,

答案:

在第一个视图控制器中使用 preparesegue 方法, 给出推送 segue 的名称, 使用 segue 名称, 在第二个视图控制器中创建谓词并使用第一个 viewcontroller。 vary 对搜索和排序很有用

代码: 1)IN (firstviewcontroller)

override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
    if(segue.identifier=="segueTest"){
        var svc = segue.destinationViewController as! MenuhospitalTableViewController
        svc.toPass = textff.text
    }
}

2)IN (秒viewcontroller)

let pred = NSPredicate(format: "(city = %@)", toPass)
        fetchRequest.predicate = pred