什么是plist文件?
- plist文件,即属性列表文件,全名是Property List,这种文件的扩展名为.plist,因此,通常被叫做plist文件。它是一种用来存储串行化后的对象的文件,在iOS开发中通常用来存储用户设置,还可以用于存储程序中经常用到而不经常改动的数据。下面就看一下如何创建和读写plist文件。
一、创建plist文件
- 在程序中通过新建文件的方式创建
快捷键 command + n
这里有一点需要注意:
命名的时候不能用Info.plist , INfo.plist, xxxInfo.plist等形式,否则会与系统中存在的Info.plist文件发生冲突。
点击Root这一行,然后通过点击右键->Add Row或者点击Root后面的加号来增加一行。
这一行中包含三个属性,key、type、value。其中key是字段属性,type是字段类型,value是字段对应的值。
Type包含7中类型,对写入的数据结构应属于7仲:
(NSString,NSData,NSDate,NSNumber,NSArray,NSDictionary)
- 代码方式创建plist文件
#define DOCMENT_USER_PATH [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES) firstObject] stringByAppendingPathComponent:@"UserData.plist"]
#define BUNDLE_USER_PATH [[NSBundle mainBundle] pathForResource:@"UserData" ofType:@"plist"]
@implementation YXDataHelper
+ (BOOL)saveUserInfoInDocument:(ACUser *)user{
BOOL isSuccess;
NSDictionary * dic = [user dictionaryWithUser:user];
NSString *document_path= DOCMENT_USER_PATH ;
NSURL *fileUrl = [NSURL fileURLWithPath:document_path];
isSuccess = [dic writeToURL:fileUrl atomically:YES];
return isSuccess;
}
二、读取plist文件
读取数据
文件是什么类型,就用什么类型的数据来接收
+ (ACUser *)getUserInfoInBundle{
NSString *path = BUNDLE_USER_PATH;
NSDictionary *dic = [[NSDictionary alloc] initWithContentsOfFile:path];
ACUser * user = [ACUser userWithDictionary:dic];
return user;
}
+ (ACUser *)getUserInfoInDocument{
NSString *path= DOCMENT_USER_PATH;
NSMutableDictionary *dic = [[NSMutableDictionary alloc] initWithContentsOfFile:path];
ACUser * user = [ACUser userWithDictionary:dic];
return user;
}
三、添加数据
+ (BOOL)saveUserInfoInDocument:(ACUser *)user{
BOOL isSuccess;
NSDictionary * dic = [user dictionaryWithUser:user];
NSString *document_path= DOCMENT_USER_PATH ;
NSURL *fileUrl = [NSURL fileURLWithPath:document_path];
isSuccess = [dic writeToURL:fileUrl atomically:YES];
return isSuccess;
}
注意:
在iOS中,只允许向沙盒中的plist文件写数据
如果plist文件在bundle,plist文件为只读,你需要将plist文件从bundle中复制到缓存目录或文档目录下,然后再修改数据
2.当向沙盒中的plist文件写数据无效时
对写入的数据结构应属于以下几种如下:(NSString,NSData,NSDate,NSNumber,NSArray,NSDictionary)
其他的数据结构是不被接受的,如 null
NSSearchPathForDirectoriesInDomains( NSSearchPathDirectory directory, NSSearchPathDomainMask domainMask, BOOL expandTilde )
方法参数说明:
directory: 搜索文件夹
domainMask: 搜索范围 (NSUserDomainMask 代表在用户中查找)
expandTilde: yes 表示路径展开,no 表示路径不展开 用~代替沙盒路径(一般情况用yes)
-(BOOL)writeToURL:(NSURL *)url atomically:(BOOL)atomically;
writeToURL 的好处是,既可以写入本地url也可以写入远程url,苹果推荐使用此方法写入plist文件
描述
将代表字典内容的属性列表写入给定的URL。
在写出文件之前,这个方法递归验证所有包含的对象是属性列表对象(NSData, NSDate, NSNumber, NSString, NSArray或NSDictionary的实例),如果所有对象不是属性列表对象,则返回NO,由于生成的作品不是一个有效的属性列表。
如果字典内容全部都是属性列表对象,则通过这些方法写入位置(通过类方法dictionaryWithContentsOfURL:或实例方法:initWithContentsOfURL)来初始化新的字典。
如果你需要更好地控制 属性列表表示,使用NSPropertyListSerialization来代替。
有关属性列表的更多信息,请参阅属性列表编程指南。
参数
aURL
字典将被写入的URL
flag
一个标记,指定输出是否原子写入。
如果标记为YES,字典将被写到辅助位置,然后辅助位置被重命名为aURL。
如果标记为NO,则字典将被直接写入aURL。
YES选项保证aURL(如果存在的话)即使在写入期间系统崩溃也不会被破坏。
如果aURL是一个不能被原子写入类型,则忽略标记
返回
如果位置写入成功,则为YES,否则为NO;
参考文档1:iOS开发,plist文件读写那些事
参考文档2:iOS开发中怎么创建Plist文件
参考文档3:【iOS】plist无法写入的原因
参考文档4:plist 文件写入与读取