Libxlsxwriter 是一个 C 库,可用于在 Excel 2007+ XLSX 文件中写入文本、数字、公式和指向多个工作表的超链接。
具体功能介绍请跳转github的库地址连接:
1、项目地址
https://github.com/jmcnamara/libxlsxwriter
2、使用手册地址
http://libxlsxwriter.github.io/
因为项目是用swift开发,所以这里主要简单介绍下swift项目下如何使用:
数据格式建议采用Array的方式存储每一组的数据,方便数据写入处理
文件名称根据实际需求定义,路径只需要文件夹路径拼接文氏岩件名即可
创建表格过程如下:
1、生成一张表格
2、创建一个sheet
3、设置表格的样式、格式(包含文字格式、文字颜色、对齐方式等)
样式设置可参考使用手册里的说明,这里大概列几个供参考:
4、关闭表格创建
如果格式不对或者样式不喜欢,可以结合实际重新设置
QuickLook的框架详解请查看:https://www.jianshu.com/p/1e886bd9dd51
可以通过QuickLook打开EXCEL文档,同时QuickLook还集成一系列功能(保存文件、传送文件等),导出文档功能可用这个框架实现,具体如何导歼指御出请看框架详解说明即可
可以通过设置样式创建各种复杂的EXCEL表格,文档说明也非常详细,用户很容易就可以利用该框架创建满足各种需求的EXCEL表格
没有EXCEL读取功能,因此读取功能只能另外处理
至此,一个简单的EXCEL创建过程已经逗唯完成。libxlsxwriter功能十分强大, 如果要生成一个复杂的表格,请仔细研读格式设置说明文档
CoreXLSX是一个库,它专注于表示基于XML的XLSX电子表格格式的底层结构。它允许您打开扩展名为.xlsx的电子表格存档,并将其内部结构映射到直接用Swift表示的模型类型中。
需要注意的是,此库仅为.xlsx格式提供只读支持。由于旧的legacy.xls电子表格格式具有完全不同的内部结构,如果您需要使用该类型的文件,请参考其他库。
如果您的.xlsx文件使用ECMA-376敏捷加密(这似乎是最流行的一种),请查看CryptoOffice库。
项目地址:https://github.com/CoreOffice/CoreXLSX
可通过系统提供的API打开,如下:
可通过UIDocumentPickerDelegate回调方法拿到对应的文件路径, 这里需要注意一个细节 ,如下图
读取文件时需要授权,不然有的文件无法读取,会报没有权限的错误提示,读取数据完成后,需要关闭授权
采用CoreXLSX相关API去读取数据,具体可参考项目文档说明,因为项目在读取数据时需要校验文档内容是否合法,不合法需要提示用户重新选择其他文件,校验规则可根据实际需求去做,以下列举个人项目的简单校验,如下图
最终rows得到的就是每组的数据,可通过遍历获取对应的数据,如有疑问,请参考官方文档或者官方DEMO
参考文献:
libxlsxwriter开源库:https://github.com/jmcnamara/libxlsxwriter
CoreXLSX开源库:https://github.com/CoreOffice/CoreXLSX
XlsxReaderWriterSwift开源库:https://github.com/mehulparmar4ever/XlsxReaderWriterSwift
谢谢各位的无私奉献。。。
NSArray *array = [[NSBundle mainBundle] pathsForResourcesOfType:@"jpg" inDirectory:@"image"]NSLog(@"array:%@",array)
首先需要在mac上新建一个文件夹叫image, 放一些图片进去,然后把整个文件夹拖到项目中,在d出的对话框中选择:Create folder references for any added folders ,这个会创建一个真实的目录,否则找到不这个目录下的文件
家目录下共有四个子目录:
Documents 目录:您应该将所有的应用程序数闭睁码据文件写入到这个目录下。这个目录用于存储用户数据或其它应该定期备份的信息。
AppName.app 目录:这是应用程序的程序包目录,包含应用程序的本身。由于应用程序必须经过签名,所以您在运行时不能对这个目录中的内容进行修改,否则可能会使应用程序无法启动。
Library 目录:轿哪这个目录下有两个子目录:Caches 和 Preferences
Preferences 目录包含应用程序的偏好设置文件。您不应该直接创建偏好设置文件,而是应该使用NSUserDefaults类来取得和设置应用程序的偏好
Caches 目录用于存放应用程序专用的支持文件,保存应用程序再次启动过程中需要的信息。
tmp 目录:这个目录用于存放临时文件,保存应用程序再次启动过程中不需要的信息。
获取这些目录路径的方法:
1,获取家目录路径的函数:
NSString *homeDir = NSHomeDirectory()
2,获取Documents目录路径的方法:早扒
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)
NSString *docDir = [paths objectAtIndex:0]
3,获取Caches目录路径的方法:
NSArray*paths=NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES)
NSString *cachesDir = [paths objectAtIndex:0]
4,获取tmp目录路径的方法:
NSString *tmpDir = NSTemporaryDirectory()
5,获取应用程序程序包中资源文件路径的方法:
例如获取程序包中一个图片资源(apple.png)路径的方法:
NSString *imagePath = [[NSBundle mainBundle] pathForResource:@”apple” ofType:@”png”]
UIImage *appleImage = [[UIImage alloc] initWithContentsOfFile:imagePath]
代码中的mainBundle类方法用于返回一个代表应用程序包的对象。
文件IO
1,将数据写到Documents目录:
- (BOOL)writeApplicationData:(NSData *)data toFile:(NSString *)fileName {
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)
NSString *docDir = [paths objectAtIndex:0]if (!docDir) { NSLog(@”Documents directory not found!”)return NO}
NSString *filePath = [docDir stringByAppendingPathComponent:fileName]
return [data writeToFile:filePath atomically:YES]}
2,从Documents目录读取数据:
- (NSData *)applicationDataFromFile:(NSString *)fileName {
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)
NSString *docDir = [paths objectAtIndex:0]
NSString *filePath = [docDir stringByAppendingPathComponent:fileName]
NSData *data = [[[NSData alloc] initWithContentsOfFile:filePath] autorelease]return data}
NSSearchPathForDirectoriesInDomains这个主要就是返回一个绝对路径用来存放我们需要储存的文件。
- (NSString *)dataFilePath {
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)
NSString *documentsDirectory = [paths objectAtIndex:0]
return [documentsDirectory stringByAppendingPathComponent:@"shoppingCar.plist"]
}
NSFileManager* fm=[NSFileManager defaultManager]
if(![fm fileExistsAtPath:[self dataFilePath]]){
//下面是对该文件进行制定路径的保存
[fm createDirectoryAtPath:[self dataFilePath] withIntermediateDirectories:YES attributes:nil error:nil]
//取得一个目录下得所有文件名
NSArray *files = [fm subpathsAtPath: [self dataFilePath] ]
//读取某个文件
NSData *data = [fm contentsAtPath:[self dataFilePath]]
//或者
NSData *data = [NSData dataWithContentOfPath:[self dataFilePath]]
}
我们的app在手机中存放的路径是:/var/mobile/Applications/4434-4453A-B453-4ADF535345ADAF344后面的目录4434-4453A-B453-4ADF535345ADAF344是iPhone自动生成的,里面包含了四个文件夹:
(1)AppName.app 目录:这是应用段雀程序的程序包目录,包含应用程序本身。由于应用改程序必须经过签名。所以再运行程序时,是不可以对这个目录进行内容修改的,否则会造成应用无法启动。
(2)Documents目录:这是文档目录。有关应用的所有数据文件应该写入到这个目录下,这个目录用于存储用户数据或者其他应该定期备份的信息。iTunes会同步改应用程序的此文件内容,适合存储一些重要的数据
(3)Libarary目录:库目录,这个目录下面还有两个子目录:Caches 和 Preferences
Preferences 目录:包含应用程序的编号设置文件,存放NSUserDefaults保存的.plist文件。iTunes同步该应用时会同步该文件夹中的内容。
Caches 目录:缓存目录。用于存储应用程序专用的支持文件,保存应用程序再次启动过程中需要的信息。ITunes不会同步改文件夹,保存一些不需要备份的数据
(4)tmp目录:临时目录。这个目录用于存放临时文件,保穗搏存应用程序再次启动过程中不再需要的信息。iTunes不会同步此文件夹,系统可能在应用没运行时就删除该目录下的文件,所以此目录适合保存应用中的一些临时文件,用完就删除。
下面就是这些文件夹猜燃祥获取路径的方法:
例子:
//下面是对该文件进行制定路径的保存
//取得一个目录下得所有文件名
//读取某个文件
//或者
}
Documents(NSDocumentDirectory)//用于写入应用相关数据文件的目录,在ios中写入这里的文件能够与iTunes共享并访问,存储在这里的文件会自动备份到云端
Library/Caches(NSCachesDirectory)//用于写入应用支持文件的目录,保存应用程序再次启动需要的信息。iTunes不会对这个目录的内容进行备份
tmp(use NSTemporaryDirectory())//这个目录用于存放临时文件,只程序终止时需要移除这些文件,当应用程序不再需要这些临时文件时,应该将其从这个目录中删除
Library/Preferences//这个目录包含应用程序的偏好设置文件,使用 NSUserDefault类进行偏好设置文件的创建、读取和修改
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)