2017-08-23 16:23:20 tongwei117 阅读数 259
import UIKit

extension Date
{
    static func nowTime(_ dateFormat : String = "YYYY-MM-dd HH:mm:ss")->String{
        let formatter = DateFormatter.init();

        formatter.dateFormat = dateFormat;

        let date = Date.init();

        return formatter.string(from: date);
    }
}
2017-10-09 17:43:12 m0_38016385 阅读数 290

Swift Core Data

首先需要创建一个模版,进去“file”->“new”->”file”->”Core Data”->”Data Model”。

然后点击右下角的“add entity”。
这里写图片描述

在Xcode里面这个Entity会变成一个NSMangedObject的一个实体。Xcode的数据库是基于SQL的,所以每一个entity会有属性、关系以及fetched properties(用于搜索?)。

可以通过NSMangedObject的两个函数来更改属性的值。

创建关系

进入视图显示模式,ctrldrag两个entity。然后修改两个relations的名字。
这里写图片描述

然后可以修改它们n对n的约束(type)。

这里写图片描述

这样子会把tweets这一个关系变成NSSet。

在代码中使用

在代码中使用这些数据库需要使用NSManagedObjectContext。

在创建开始的项目的时候,如果选择了“Use Core Data”,那么Xcode会自动帮我们创建一些方法(在AppDelegate)。当然也可以我们自己创建UIManagedDocument。

创建代码
首先为他们创建subclass。
这里写图片描述

记得要选择swift。

不过创建的时候出现了错误提示,要解决这个问题可以参考这里

插入行至数据库

NSEntityDescription.insertNewObjectForEntityForName("Tweet", inManagedObjectContext: moc)

这里写图片描述

访问某一行的属性(列)

func valueForKey(String) -> AnyObject?
func setValue(AnyObject?, forKey: String )

保存

context.save()

但是这个方法有一个问题,就是可能会抛出错误,我们必须学习一下swift中错误抛出的处理方式。

删除

mangedObjectContext.deleteObject(tweet)

搜索
使用NSFetchRequest来进行。你需要规定想抓取的Entity,以及抓取的规模和限制。

同时也需要规定返回的string的排序方式(使用NSSortDescripitor)。
这里写图片描述

NSPredicate则是规定我们需要什么,注意其中的%@有点像printf里的%f。
这里写图片描述

上面的图片返回的是joe在aDate后创建的tweets以及screenName是CS193p的tweeter。

例子
这里写图片描述
这里写图片描述

Thrown Errors

do {
    try context.save()
} catch let error {
    //里面会有NSError,它提供一些方法可以处理这些错误。 
}

UITableView和Core Data的交互

因为大量的数据非常适合使用Table View来展示,所以xcode直接提供了一个NSFetchedResultsController类来实现。它可以总是和数据库同步。
这里写图片描述
这里写图片描述

创建一个NSFetchedResultsController的方法:
这里写图片描述

2019-12-09 16:36:52 santiagozhang 阅读数 32

在这篇文章里面介绍了data.frame的基本操作data.frame基本操作。今天写一下data.frame的排序。R基本package里面用的比较多的排序function是order,sort是用来排序vector。

order

这个是order的用法

order(..., na.last = TRUE, decreasing = FALSE,
      method = c("auto", "shell", "radix"))

… 代表的是排序数据,可以是vector,或者多个vectors。
na.last 对空值的处理。TRUE的话,NA值会被排在最后面,FALSE排在最前面。
decreasing 是设置生序排列还是降序排列。默认是生序排列。
method = c(“auto”, “shell”, “radix”)
shell是指希尔排序。百科希尔排序
radix 是基数排序。百科基数排序
auto是数据类型为short numeric vectors, integer vectors, logical vectors and factors。其余的用shell。
我们来看一个简单的例子。

studentAges <- c(23, 34, 34, 89, 90, 35)
studentNames <- c("Bob","Henry","Lily","LiMing","Rose","Jack")
studentDF <- data.frame(studentAges, studentNames)
studentDF
order(studentDF$studentAges)
studentDF[order(studentDF$studentAges),]

order example用多个columns排序,并使用降序。

studentDF[order(studentDF$studentAges, -studentDF$studentNames),]

多个columns和降序

sort

sort的用法,参数和order差不多。

sort(x, decreasing = FALSE, na.last = NA, ...)
2018-05-04 10:06:25 yingBi2014 阅读数 8829
let str:String = "意大利"
//字符串转Data
let data = str.data(using: String.Encoding.utf8)
//Data转字符串
let newStr = String(data: data!, encoding: String.Encoding.utf8)
print("data=" , data!  , "\n" ,  "newStr=" , newStr!)

输出结果

data= 9 bytes 
newStr= 意大利

2018-07-27 18:19:28 PrecipitantPan 阅读数 133

    swift存储数据使用core data,它是一套ORM框架,苹果力荐,但是性能不及sqlite,而且除了真tm复杂我也没看到有什么亮点,不过多学点总还是好的,黑人问号。

    Xcode提供一套可视化生成Entity,但是如果按照教程去做,自动使用默认的Class生成会报错,在YourEnityproperties.swift加上@obj或者直接选none生成,手撸也不费事的

    可以自己封装一下对context使用,注意container的名字需要修改,改成当前工程名,否则会抱实体不对应的错

import Foundation
import CoreData

class DataBase {
    
    static let shared = DataBase()
    private init() {
        
    }
    
    // MARK: - Core Data stack
    
    lazy var persistentContainer: NSPersistentContainer = {
        /*
         The persistent container for the application. This implementation
         creates and returns a container, having loaded the store for the
         application to it. This property is optional since there are legitimate
         error conditions that could cause the creation of the store to fail.
         */
        let container = NSPersistentContainer(name: "PFReminder")
        container.loadPersistentStores(completionHandler: { (storeDescription, error) in
            if let error = error as NSError? {
                // Replace this implementation with code to handle the error appropriately.
                // fatalError() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
                
                /*
                 Typical reasons for an error here include:
                 * The parent directory does not exist, cannot be created, or disallows writing.
                 * The persistent store is not accessible, due to permissions or data protection when the device is locked.
                 * The device is out of space.
                 * The store could not be migrated to the current model version.
                 Check the error message to determine what the actual problem was.
                 */
                fatalError("Unresolved error \(error), \(error.userInfo)")
            }
        })
        return container
    }()
    
    // MARK: - Core Data Saving support
    
    func saveContext () {
        let context = persistentContainer.viewContext
        if context.hasChanges {
            do {
                try context.save()
            } catch {
                // Replace this implementation with code to handle the error appropriately.
                // fatalError() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
                let nserror = error as NSError
                fatalError("Unresolved error \(nserror), \(nserror.userInfo)")
            }
        }
    }
}

    个人吐槽的是这玩意儿的CURD确实糟糕...尤其是删,改...

func selectAll() -> [Notification]? {
        let managedObjectContext = db.persistentContainer.viewContext
        let fetchRequest = NSFetchRequest<NSFetchRequestResult>(entityName: "Notification")
       
        do {
            let fetchedResults = try managedObjectContext.fetch(fetchRequest) as? [Notification]
            return fetchedResults
        } catch {
            fatalError("获取失败")
        }
    }
    
    func saveNotification(title: String, body: String) {
        let date = DateUtil().getCurentDate()
        let managedObjectContext = db.persistentContainer.viewContext
       
        let entity = NSEntityDescription.entity(forEntityName: "Notification", in: managedObjectContext)
        let notification = NSManagedObject(entity: entity!, insertInto: managedObjectContext)
        
        notification.setValue(date, forKey: "id")
        notification.setValue(title, forKey: "title")
        notification.setValue(body, forKey: "body")
        
        do {
            try managedObjectContext.save()
        } catch  {
            fatalError("无法保存")
        }
        
        notifications.append(notification)
    }
    

 

swift data 转byte

阅读数 1012

没有更多推荐了,返回首页