我是Swift 3编码的新手。
我正在尝试从iPhone“复制”电话应用程序,但是在单元格中显示数据时出现了一些问题,但它们没有出现(显然那里有一些数据是从Core Data类中恢复的)。
核心数据类包含一个具有一些属性的联系人,例如“firstName”,“lastName”,“phoneNumber”等。我在X.xcdatamodeld中创建了它。那些属性
在另一个VC中设置并保存在其中。
我想在单元格中显示的是每个联系人的名字,这些名字按字母顺序排列,例如电话应用程序。
这是我到目前为止所拥有的。

extension Contact {
var titleFirstLetter: String {
    return String(firstName![firstName!.startIndex]).uppercased()
 }
}

class MainTableViewController: UITableViewController {
var listOfContacts = [Contact]()
var sortedFirstLetters: [String] = []
var sections: [[Contact]] = [[]]

struct Storyboard {
    static let cellIdentifier = "Cell"
    static let showDetailIdentifier = "showDetail"
    static let showInformationIdentifier = "showInformationVC"
}

 override func viewDidLoad() {
    super.viewDidLoad()

    tableView.delegate = self
    tableView.dataSource = self

    let firstLetters = listOfContacts.map { $0.titleFirstLetter }

    let uniqueFirstLetters = Array(Set(firstLetters))

    sortedFirstLetters = uniqueFirstLetters.sorted()
    sections = sortedFirstLetters.map { firstLetter in
        return listOfContacts.filter { $0.titleFirstLetter == firstLetter }.sorted { $0.firstName! < $1.firstName! }
    }
 }

 override func viewWillAppear(_ animated: Bool) {
    super.viewWillAppear(animated)

    getData()
    tableView.reloadData()
 }

 func getData() {
    // 1. Create context
    let context = CoreDataController.persistentContainer.viewContext

    // 2. RecoverData from Database with fetchRequest
    do {
        try listOfContacts = context.fetch(Contact.fetchRequest())
    } catch {
        print("Error \(error.localizedDescription)")
    }
}

// MARK: - Tableview data source

override func numberOfSections(in tableView: UITableView) -> Int {
     return sections.count
}

override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return sections[section].count
}

override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let contact = sections[indexPath.section][indexPath.row]

    let cell = tableView.dequeueReusableCell(withIdentifier: Storyboard.cellIdentifier, for: indexPath)
    cell.textLabel?.text = contact.firstName

    return cell
}

 override func sectionIndexTitles(for tableView: UITableView) -> [String]? {
    return sortedFirstLetters
}


override func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
   return sortedFirstLetters[section]
}

注意:CoreDataController是我在管理检索并将其保存到CoreData时感到很舒服的一类(我所做的就是从AppDelegate.swift复制CoreData的生成代码)
希望您能帮助我弄清楚为什么它不起作用。提前致谢!

最佳答案

应该将NSSortDescriptor与您获取的查询一起使用,例如:

  let sectionSortDescriptor = NSSortDescriptor(key: "first_name", ascending: true)
  let sortDescriptors = [sectionSortDescriptor]
 fetchRequest.sortDescriptors = sortDescriptors
 let fetchedPerson = try context.fetch(fetchRequest) as! [Contact]

它可以解决您的问题。如果您在此之后遇到问题,请告诉我。

关于ios - 如何使用Core Data按节按字母顺序对tableView中的数据进行排序?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/44860316/

10-13 05:42
查看更多