Ios 删除CoreData对象

Ios 删除CoreData对象,ios,swift,uitableview,core-data,Ios,Swift,Uitableview,Core Data,我仍然在为开始本周的工作而挣扎,哈哈。我终于成功地保存和获取了我的数组,现在是编辑和删除的时候了 我先添加delete函数,但传入正确参数时遇到问题: 核心数据功能: class CDHandler: NSObject { private class func getContext() -> NSManagedObjectContext { let appDelegate = UIApplication.shared.delegate as! AppDelegate re

我仍然在为开始本周的工作而挣扎,哈哈。我终于成功地保存和获取了我的数组,现在是编辑和删除的时候了

我先添加delete函数,但传入正确参数时遇到问题:

核心数据功能:

class CDHandler: NSObject {

private class func getContext() -> NSManagedObjectContext {
    let appDelegate = UIApplication.shared.delegate as! AppDelegate
    return appDelegate.persistentContainer.viewContext
}

class func saveObject(name:String, code:String, symbol:String, placeholder:String, amount:String) -> Bool {
    let context = getContext()
    let entity = NSEntityDescription.entity(forEntityName: "CryptosMO", in: context)
    let managedObject = NSManagedObject(entity: entity!, insertInto: context)

    managedObject.setValue(name, forKey: "name")
    managedObject.setValue(code, forKey: "code")
    managedObject.setValue(symbol, forKey: "symbol")
    managedObject.setValue(placeholder, forKey: "placeholder")
    managedObject.setValue(amount, forKey: "amount")

    do {
        try context.save()
        return true
    } catch {
        return false
    }
}

class func fetchObject() -> [CryptosMO]? {
    let context = getContext()
    var cryptos: [CryptosMO]? = nil

    do {
        cryptos = try context.fetch(CryptosMO.fetchRequest()) as? [CryptosMO]
        return cryptos
    } catch {
        return cryptos
    }
}

class func deleteObject(crypto: CryptosMO) -> Bool {
    let context = getContext()
    context.delete(crypto)

    do {
        try context.save()
        return true
    } catch {
        return false
    }
}
    if addedCrypto != "" {
        if addedCrypto == "Bitcoin BTC" {
            if CDHandler.saveObject(name: "Bitcoin", code: "bitcoin", symbol: "BTC", placeholder: "BTC Amount", amount: "0.0") {
                for crypto in CDHandler.fetchObject()! {
                    print("\(String(describing: crypto.name))'s symbol is \(String(describing: crypto.symbol))")
                }
            }
        }
    }
override func viewWillAppear(_ animated: Bool) {
    tableView.delegate = self
    tableView.dataSource = self


    if CDHandler.fetchObject() != nil {
        cryptos = CDHandler.fetchObject()!
        tableView.reloadData()
    }
}
extension WalletTableViewController: UITableViewDelegate, UITableViewDataSource, CryptoCellDelegate {


func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return cryptos.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

    let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) as! WalletTableViewCell

    cell.cryptoNameLabel.text = cryptos[indexPath.row].name
    cell.amountTextField.placeholder = cryptos[indexPath.row].placeholder

    cell.delegate = self
    cell.amountTextField.delegate = self

    return cell
}
func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
    if editingStyle == .delete {
        cryptos.remove(at: indexPath.row)
        tableView.deleteRows(at: [indexPath], with: .fade)
        CDHandler.deleteObject(crypto: cryptos) // <----- Cannot convert value of type '[CryptosMO]' to expected argument type 'CryptosMO'
    }
}
}

创建和保存数组:

class CDHandler: NSObject {

private class func getContext() -> NSManagedObjectContext {
    let appDelegate = UIApplication.shared.delegate as! AppDelegate
    return appDelegate.persistentContainer.viewContext
}

class func saveObject(name:String, code:String, symbol:String, placeholder:String, amount:String) -> Bool {
    let context = getContext()
    let entity = NSEntityDescription.entity(forEntityName: "CryptosMO", in: context)
    let managedObject = NSManagedObject(entity: entity!, insertInto: context)

    managedObject.setValue(name, forKey: "name")
    managedObject.setValue(code, forKey: "code")
    managedObject.setValue(symbol, forKey: "symbol")
    managedObject.setValue(placeholder, forKey: "placeholder")
    managedObject.setValue(amount, forKey: "amount")

    do {
        try context.save()
        return true
    } catch {
        return false
    }
}

class func fetchObject() -> [CryptosMO]? {
    let context = getContext()
    var cryptos: [CryptosMO]? = nil

    do {
        cryptos = try context.fetch(CryptosMO.fetchRequest()) as? [CryptosMO]
        return cryptos
    } catch {
        return cryptos
    }
}

class func deleteObject(crypto: CryptosMO) -> Bool {
    let context = getContext()
    context.delete(crypto)

    do {
        try context.save()
        return true
    } catch {
        return false
    }
}
    if addedCrypto != "" {
        if addedCrypto == "Bitcoin BTC" {
            if CDHandler.saveObject(name: "Bitcoin", code: "bitcoin", symbol: "BTC", placeholder: "BTC Amount", amount: "0.0") {
                for crypto in CDHandler.fetchObject()! {
                    print("\(String(describing: crypto.name))'s symbol is \(String(describing: crypto.symbol))")
                }
            }
        }
    }
override func viewWillAppear(_ animated: Bool) {
    tableView.delegate = self
    tableView.dataSource = self


    if CDHandler.fetchObject() != nil {
        cryptos = CDHandler.fetchObject()!
        tableView.reloadData()
    }
}
extension WalletTableViewController: UITableViewDelegate, UITableViewDataSource, CryptoCellDelegate {


func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return cryptos.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

    let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) as! WalletTableViewCell

    cell.cryptoNameLabel.text = cryptos[indexPath.row].name
    cell.amountTextField.placeholder = cryptos[indexPath.row].placeholder

    cell.delegate = self
    cell.amountTextField.delegate = self

    return cell
}
func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
    if editingStyle == .delete {
        cryptos.remove(at: indexPath.row)
        tableView.deleteRows(at: [indexPath], with: .fade)
        CDHandler.deleteObject(crypto: cryptos) // <----- Cannot convert value of type '[CryptosMO]' to expected argument type 'CryptosMO'
    }
}
获取TableView的核心数据:

class CDHandler: NSObject {

private class func getContext() -> NSManagedObjectContext {
    let appDelegate = UIApplication.shared.delegate as! AppDelegate
    return appDelegate.persistentContainer.viewContext
}

class func saveObject(name:String, code:String, symbol:String, placeholder:String, amount:String) -> Bool {
    let context = getContext()
    let entity = NSEntityDescription.entity(forEntityName: "CryptosMO", in: context)
    let managedObject = NSManagedObject(entity: entity!, insertInto: context)

    managedObject.setValue(name, forKey: "name")
    managedObject.setValue(code, forKey: "code")
    managedObject.setValue(symbol, forKey: "symbol")
    managedObject.setValue(placeholder, forKey: "placeholder")
    managedObject.setValue(amount, forKey: "amount")

    do {
        try context.save()
        return true
    } catch {
        return false
    }
}

class func fetchObject() -> [CryptosMO]? {
    let context = getContext()
    var cryptos: [CryptosMO]? = nil

    do {
        cryptos = try context.fetch(CryptosMO.fetchRequest()) as? [CryptosMO]
        return cryptos
    } catch {
        return cryptos
    }
}

class func deleteObject(crypto: CryptosMO) -> Bool {
    let context = getContext()
    context.delete(crypto)

    do {
        try context.save()
        return true
    } catch {
        return false
    }
}
    if addedCrypto != "" {
        if addedCrypto == "Bitcoin BTC" {
            if CDHandler.saveObject(name: "Bitcoin", code: "bitcoin", symbol: "BTC", placeholder: "BTC Amount", amount: "0.0") {
                for crypto in CDHandler.fetchObject()! {
                    print("\(String(describing: crypto.name))'s symbol is \(String(describing: crypto.symbol))")
                }
            }
        }
    }
override func viewWillAppear(_ animated: Bool) {
    tableView.delegate = self
    tableView.dataSource = self


    if CDHandler.fetchObject() != nil {
        cryptos = CDHandler.fetchObject()!
        tableView.reloadData()
    }
}
extension WalletTableViewController: UITableViewDelegate, UITableViewDataSource, CryptoCellDelegate {


func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return cryptos.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

    let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) as! WalletTableViewCell

    cell.cryptoNameLabel.text = cryptos[indexPath.row].name
    cell.amountTextField.placeholder = cryptos[indexPath.row].placeholder

    cell.delegate = self
    cell.amountTextField.delegate = self

    return cell
}
func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
    if editingStyle == .delete {
        cryptos.remove(at: indexPath.row)
        tableView.deleteRows(at: [indexPath], with: .fade)
        CDHandler.deleteObject(crypto: cryptos) // <----- Cannot convert value of type '[CryptosMO]' to expected argument type 'CryptosMO'
    }
}
表格视图功能:

class CDHandler: NSObject {

private class func getContext() -> NSManagedObjectContext {
    let appDelegate = UIApplication.shared.delegate as! AppDelegate
    return appDelegate.persistentContainer.viewContext
}

class func saveObject(name:String, code:String, symbol:String, placeholder:String, amount:String) -> Bool {
    let context = getContext()
    let entity = NSEntityDescription.entity(forEntityName: "CryptosMO", in: context)
    let managedObject = NSManagedObject(entity: entity!, insertInto: context)

    managedObject.setValue(name, forKey: "name")
    managedObject.setValue(code, forKey: "code")
    managedObject.setValue(symbol, forKey: "symbol")
    managedObject.setValue(placeholder, forKey: "placeholder")
    managedObject.setValue(amount, forKey: "amount")

    do {
        try context.save()
        return true
    } catch {
        return false
    }
}

class func fetchObject() -> [CryptosMO]? {
    let context = getContext()
    var cryptos: [CryptosMO]? = nil

    do {
        cryptos = try context.fetch(CryptosMO.fetchRequest()) as? [CryptosMO]
        return cryptos
    } catch {
        return cryptos
    }
}

class func deleteObject(crypto: CryptosMO) -> Bool {
    let context = getContext()
    context.delete(crypto)

    do {
        try context.save()
        return true
    } catch {
        return false
    }
}
    if addedCrypto != "" {
        if addedCrypto == "Bitcoin BTC" {
            if CDHandler.saveObject(name: "Bitcoin", code: "bitcoin", symbol: "BTC", placeholder: "BTC Amount", amount: "0.0") {
                for crypto in CDHandler.fetchObject()! {
                    print("\(String(describing: crypto.name))'s symbol is \(String(describing: crypto.symbol))")
                }
            }
        }
    }
override func viewWillAppear(_ animated: Bool) {
    tableView.delegate = self
    tableView.dataSource = self


    if CDHandler.fetchObject() != nil {
        cryptos = CDHandler.fetchObject()!
        tableView.reloadData()
    }
}
extension WalletTableViewController: UITableViewDelegate, UITableViewDataSource, CryptoCellDelegate {


func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return cryptos.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

    let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) as! WalletTableViewCell

    cell.cryptoNameLabel.text = cryptos[indexPath.row].name
    cell.amountTextField.placeholder = cryptos[indexPath.row].placeholder

    cell.delegate = self
    cell.amountTextField.delegate = self

    return cell
}
func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
    if editingStyle == .delete {
        cryptos.remove(at: indexPath.row)
        tableView.deleteRows(at: [indexPath], with: .fade)
        CDHandler.deleteObject(crypto: cryptos) // <----- Cannot convert value of type '[CryptosMO]' to expected argument type 'CryptosMO'
    }
}
扩展WalletTableViewController:UITableViewDelegate、UITableViewDataSource、CryptoCellDelegate{ func tableView(tableView:UITableView,numberofrowsinssection:Int)->Int{ 返回cryptos.count } func tableView(tableView:UITableView,cellForRowAt indexath:indexPath)->UITableViewCell{ 将cell=tableView.dequeueReusableCell(标识符为“cell”,for:indexPath)设为!WalletTableViewCell cell.cryptoNameLabel.text=cryptos[indexath.row].name cell.amountTextField.placeholder=加密[indexPath.row]。占位符 cell.delegate=self cell.amountTextField.delegate=self 返回单元 } func tableView(tableView:UITableView,commit editingStyle:UITableViewCellEditingStyle,forRowAt indexPath:indexPath){ 如果editingStyle==.delete{ cryptos.remove(位于:indexPath.row) tableView.deleteRows(位于:[indexPath],带:.fade)
CDHandler.deleteObject(crypto:cryptos)//只需调用此方法,并通过要删除的
managedObject
传递实体:

func deleteData(entity:String,deleteObject:NSManagedObject){
    //for iOS 10+
           // let delegate = UIApplication.shared.delegate as? AppDelegate
           // let context = delegate!.persistentContainer.viewContext
            let context = getContext()
            context.delete(deleteObject)
            do {
                try context.save()
            } catch let error as NSError {
                print("Could not save. \(error), \(error.userInfo)")
            }

        }


 func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
        if editingStyle == .delete {
        let selectedManagedObject = cryptos[indexPath.row]
        deleteData(entity:"yourEntityName",deleteObject: selectedManagedObject)
            cryptos.remove(at: indexPath.row)
            tableView.deleteRows(at: [indexPath], with: .fade)
        }
    }
与可以编辑的保存方法相同,只需传递要编辑的
managedObject

class func updateObject(name:String, code:String, symbol:String, placeholder:String, amount:String,selectedManagedObject:NSManagedObject) {
    let context = getContext()

    selectedManagedObject.setValue(name, forKey: "name")
    selectedManagedObject.setValue(code, forKey: "code")
    selectedManagedObject.setValue(symbol, forKey: "symbol")
    selectedManagedObject.setValue(placeholder, forKey: "placeholder")
    selectedManagedObject.setValue(amount, forKey: "amount")

    do {
        try context.save()
    } catch let error as NSError {
        print("Could not save. \(error), \(error.userInfo)")
    }

}

只需调用此方法,并使用要删除的
managedObject
传递实体:

func deleteData(entity:String,deleteObject:NSManagedObject){
    //for iOS 10+
           // let delegate = UIApplication.shared.delegate as? AppDelegate
           // let context = delegate!.persistentContainer.viewContext
            let context = getContext()
            context.delete(deleteObject)
            do {
                try context.save()
            } catch let error as NSError {
                print("Could not save. \(error), \(error.userInfo)")
            }

        }


 func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
        if editingStyle == .delete {
        let selectedManagedObject = cryptos[indexPath.row]
        deleteData(entity:"yourEntityName",deleteObject: selectedManagedObject)
            cryptos.remove(at: indexPath.row)
            tableView.deleteRows(at: [indexPath], with: .fade)
        }
    }
与可以编辑的保存方法相同,只需传递要编辑的
managedObject

class func updateObject(name:String, code:String, symbol:String, placeholder:String, amount:String,selectedManagedObject:NSManagedObject) {
    let context = getContext()

    selectedManagedObject.setValue(name, forKey: "name")
    selectedManagedObject.setValue(code, forKey: "code")
    selectedManagedObject.setValue(symbol, forKey: "symbol")
    selectedManagedObject.setValue(placeholder, forKey: "placeholder")
    selectedManagedObject.setValue(amount, forKey: "amount")

    do {
        try context.save()
    } catch let error as NSError {
        print("Could not save. \(error), \(error.userInfo)")
    }

}

调用
CDHandler.deleteObject(crypto:…)
时,只需传递
(crypto:cryptos[indexath.row])
而不是
(crypto:cryptos)


调用
CDHandler.deleteObject(crypto:…)
时,只需传递
(crypto:cryptos[indexath.row])
而不是
(crypto:cryptos)


非常感谢,但是我得到
无法用'indepath'类型的索引为'[CryptosMO]'类型的值下标
对不起,indepath。row@martin它应该是
cryptos[indexPath.row]
非常感谢,但是我得到
无法为“[CryptosMO]类型的值下标'的索引类型为'indepath'
对不起,是indepath。row@martin它应该是
cryptos[indexPath.row]
非常感谢Shabbir!这很好!我可以向您咨询服务吗?如果您可以添加
编辑的方法,那就太棒了!非常感谢Shabbir!这很好!我可以向您咨询服务吗?如果您可以添加
编辑的方法,那就太棒了!