iOS 生成Excel文件
来源:互联网 发布:粒子滤波算法流程图 编辑:程序博客网 时间:2024/05/17 04:53
- (void)createXLSFile {
// 创建存放XLS文件数据的数组
NSMutableArray *xlsDataMuArr = [[NSMutableArray alloc] init];
// 第一行内容
[xlsDataMuArr addObject:@"Time"];
[xlsDataMuArr addObject:@"Address"];
[xlsDataMuArr addObject:@"Person"];
[xlsDataMuArr addObject:@"Reason"];
[xlsDataMuArr addObject:@"Process"];
[xlsDataMuArr addObject:@"Result"];
// 100行数据
for (int i = 0; i < 100; i ++) {
[xlsDataMuArr addObject:@"2016-12-06 17:18:40"];
[xlsDataMuArr addObject:@"GuangZhou"];
[xlsDataMuArr addObject:@"Mr.Liu"];
[xlsDataMuArr addObject:@"Buy"];
[xlsDataMuArr addObject:@"TaoBao"];
[xlsDataMuArr addObject:@"Debt"];
}
// 把数组拼接成字符串,连接符是 \t(功能同键盘上的tab键)
NSString *fileContent = [xlsDataMuArr componentsJoinedByString:@"\t"];
// 字符串转换为可变字符串,方便改变某些字符
NSMutableString *muStr = [fileContent mutableCopy];
// 新建一个可变数组,存储每行最后一个\t的下标(以便改为\n)
NSMutableArray *subMuArr = [NSMutableArray array];
for (int i = 0; i < muStr.length; i ++) {
NSRange range = [muStr rangeOfString:@"\t" options:NSBackwardsSearch range:NSMakeRange(i, 1)];
if (range.length == 1) {
[subMuArr addObject:@(range.location)];
}
}
// 替换末尾\t
for (NSUInteger i = 0; i < subMuArr.count; i ++) {
#warning 下面的6是列数,根据需求修改
if ( i > 0 && (i%6 == 0) ) {
[muStr replaceCharactersInRange:NSMakeRange([[subMuArr objectAtIndex:i-1] intValue], 1) withString:@"\n"];
}
}
// 文件管理器
NSFileManager *fileManager = [[NSFileManager alloc]init];
//使用UTF16才能显示汉字;如果显示为#######是因为格子宽度不够,拉开即可
NSData *fileData = [muStr dataUsingEncoding:NSUTF16StringEncoding];
// 文件路径
NSString *path = NSHomeDirectory();
name = @"export";
houzui = @"xls";
quanming = @"export.xls";
lujing = filePath;
// 生成xls文件
[fileManager createFileAtPath:filePath contents:fileData attributes:nil];
}
// 创建存放XLS文件数据的数组
NSMutableArray *xlsDataMuArr = [[NSMutableArray alloc] init];
// 第一行内容
[xlsDataMuArr addObject:@"Time"];
[xlsDataMuArr addObject:@"Address"];
[xlsDataMuArr addObject:@"Person"];
[xlsDataMuArr addObject:@"Reason"];
[xlsDataMuArr addObject:@"Process"];
[xlsDataMuArr addObject:@"Result"];
// 100行数据
for (int i = 0; i < 100; i ++) {
[xlsDataMuArr addObject:@"2016-12-06 17:18:40"];
[xlsDataMuArr addObject:@"GuangZhou"];
[xlsDataMuArr addObject:@"Mr.Liu"];
[xlsDataMuArr addObject:@"Buy"];
[xlsDataMuArr addObject:@"TaoBao"];
[xlsDataMuArr addObject:@"Debt"];
}
// 把数组拼接成字符串,连接符是 \t(功能同键盘上的tab键)
NSString *fileContent = [xlsDataMuArr componentsJoinedByString:@"\t"];
// 字符串转换为可变字符串,方便改变某些字符
NSMutableString *muStr = [fileContent mutableCopy];
// 新建一个可变数组,存储每行最后一个\t的下标(以便改为\n)
NSMutableArray *subMuArr = [NSMutableArray array];
for (int i = 0; i < muStr.length; i ++) {
NSRange range = [muStr rangeOfString:@"\t" options:NSBackwardsSearch range:NSMakeRange(i, 1)];
if (range.length == 1) {
[subMuArr addObject:@(range.location)];
}
}
// 替换末尾\t
for (NSUInteger i = 0; i < subMuArr.count; i ++) {
#warning 下面的6是列数,根据需求修改
if ( i > 0 && (i%6 == 0) ) {
[muStr replaceCharactersInRange:NSMakeRange([[subMuArr objectAtIndex:i-1] intValue], 1) withString:@"\n"];
}
}
// 文件管理器
NSFileManager *fileManager = [[NSFileManager alloc]init];
//使用UTF16才能显示汉字;如果显示为#######是因为格子宽度不够,拉开即可
NSData *fileData = [muStr dataUsingEncoding:NSUTF16StringEncoding];
// 文件路径
NSString *path = NSHomeDirectory();
NSString *filePath = [path stringByAppendingPathComponent:@"/Documents/export.xls"];
NSLog(@"文件路径:\n%@",filePath);name = @"export";
houzui = @"xls";
quanming = @"export.xls";
lujing = filePath;
// 生成xls文件
[fileManager createFileAtPath:filePath contents:fileData attributes:nil];
}
阅读全文
0 0
- iOS 生成Excel文件
- JAVA生成EXCEL文件
- JAVA生成EXCEL文件
- JSP生成EXCEL文件
- php生成EXCEL文件
- Java生成EXCEL文件
- c#生成excel文件
- JAVA生成EXCEL文件
- jxls生成Excel文件
- java生成Excel文件
- php生成excel文件
- java生成Excel文件
- JAVA生成EXCEL文件
- 生成excel文件代码
- 生成Excel文件
- PHPexcel 生成 excel 文件
- XLSTransformer生成excel文件
- android 生成Excel文件
- malloc 和new的区别
- 垃圾收集器
- 多条目
- 1036. 跟奥巴马一起编程(15)——C语言
- 条件选择语句if else switch
- iOS 生成Excel文件
- 安卓自定义长按事件(延长响应时间)
- /etc/init.d/rcS内容分析
- springMVC面试集锦(一)
- iOS强制横竖屏
- C/C++学习笔记1
- maven项目pom文件报web.xml is missing and <failOnMissingWebXml> is set to true
- oracle_awr
- FreeCodeCamp 学习笔记(一)HTML&CSS