iOS 开发将数据写入Excel 并且从Excel中读取数据

iOS 开发将数据写入Excel 并且从Excel中读取数据

1、将数据写入Excel

获取本地沙河地址
NSString *documentDirectory = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];
/// 获取当前日期
NSString *xlsxName = excelName;
  // 拼接 cache路径 + 名为xlsxName的文件   注意:该路径下的文件名一定要和后续导出的文件名保持一致,否则后续执行导出操作时,读取不到该文件
NSString *filename =[documentDirectory stringByAppendingPathComponent:xlsxName];
创建excel 使用xlsxwriter 开源库
lxw_workbook  *workbook  = workbook_new([filename UTF8String]);
lxw_worksheet *worksheet = workbook_add_worksheet(workbook, @"desipot".UTF8String);
创建excel样式
lxw_format *columnTitleformat = workbook_add_format(workbook);
// 内容垂直居中
format_set_align(columnTitleformat, LXW_ALIGN_VERTICAL_CENTER);
// 内容水平居中
format_set_align(columnTitleformat, LXW_ALIGN_CENTER);
写入数据
 NSArray *titles = [self getTitls];
    /// 二级标题  模型对应的字段
    NSMutableArray *attrs = [self getAttrs];
    int i = 0;
    for (NSString *title in titles) {
        worksheet_write_string(worksheet,0,i, [title UTF8String], columnTitleformat);
        worksheet_write_string(worksheet,1,i, [attrs[i] UTF8String], columnTitleformat);
        for (int j = 0; j < dataArray.count; j++) {
            ZYWealthDataItemModel *md = dataArray[j];
            NSMutableDictionary *mdDic = [md yy_modelToJSONObject];
            
            NSString *keySting = attrs[i];
            NSString *valueString =  @"";
            if([keySting isEqual:@"isupLoad"]){
                valueString = [NSString stringWithFormat:@"%d",j + 2];
            }else{
                valueString = [mdDic valueForKey:attrs[i]];
            }
            worksheet_write_string(worksheet,j + 2,i, [valueString UTF8String], columnTitleformat);
        }
        i ++;
    }
关闭写入
int resut = workbook_close(workbook);
if(resut != 0){
    NSLog(@"falied");
}
完整代码
NSString *documentDirectory = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];
/// 获取当前日期
NSString *xlsxName = excelName;
  // 拼接 cache路径 + 名为xlsxName的文件   注意:该路径下的文件名一定要和后续导出的文件名保持一致,否则后续执行导出操作时,读取不到该文件
NSString *filename =[documentDirectory stringByAppendingPathComponent:xlsxName];


/// 创建excel表格  char * 类型
lxw_workbook  *workbook  = workbook_new([filename UTF8String]);
lxw_worksheet *worksheet = workbook_add_worksheet(workbook, @"desipot".UTF8String);

lxw_format *format = workbook_add_format(workbook);
format_set_bold(format);
worksheet_set_column(worksheet, 0, 0, 20, NULL);

lxw_format *columnTitleformat = workbook_add_format(workbook);
// 内容垂直居中
format_set_align(columnTitleformat, LXW_ALIGN_VERTICAL_CENTER);
// 内容水平居中
format_set_align(columnTitleformat, LXW_ALIGN_CENTER);
/// 标题
NSArray *titles = [self getTitls];
/// 二级标题  模型对应的字段
NSMutableArray *attrs = [self getAttrs];


int i = 0;
for (NSString *title in titles) {
    worksheet_write_string(worksheet,0,i, [title UTF8String], columnTitleformat);
    worksheet_write_string(worksheet,1,i, [attrs[i] UTF8String], columnTitleformat);
    for (int j = 0; j < dataArray.count; j++) {
        ZYWealthDataItemModel *md = dataArray[j];
        NSMutableDictionary *mdDic = [md yy_modelToJSONObject];
        
        NSString *keySting = attrs[i];
        NSString *valueString =  @"";
        if([keySting isEqual:@"isupLoad"]){
            valueString = [NSString stringWithFormat:@"%d",j + 2];
        }else{
            valueString = [mdDic valueForKey:attrs[i]];
        }
        worksheet_write_string(worksheet,j + 2,i, [valueString UTF8String], columnTitleformat);
    }
    i ++;
}
int resut = workbook_close(workbook);
if(resut != 0){
    NSLog(@"falied");
}

2、读取Excel 中的数据

获取本地沙河地址
NSString *paths =   [[NSBundle mainBundle]pathForResource:@"list" ofType:@".xlsx"];
解析数据
LAWExcelTool.shareInstance.delegate = self;
[LAWExcelTool.shareInstance parserExcelWithPath:paths];
协议数据返回
- (void)parser:(LAWExcelTool *)parser success:(id)responseObj{
    NSArray * array = (NSArray *)responseObj;
    NSInteger startIndex = 0;
    NSInteger endIndex = 0;
    
    
    NSInteger startCompanyIndex = 0;
    NSInteger endCompanyIndex = 0;
    
    NSUInteger index = 0;
    for (ZContent *content in array) {
        /// 获取所有的 股票代码
        ///
        if([content.value isEqual:@"stockName"]) startCompanyIndex = index;
        if([content.value isEqual:@"股票代码"]) endCompanyIndex = index;

        if([content.value isEqual:@"stockCode"]) startIndex = index;
        if([content.value isEqual:@"公司名称"]) endIndex = index;
                
        index ++;
    }
    
    NSMutableArray *items = [[NSMutableArray alloc]init];
    for(NSUInteger j = startIndex + 1; j < endIndex; j++){
        ZContent *content = array[j];
        ZContent *company = array[j-startIndex + startCompanyIndex];
        ZYWealthDataItemModel *model = [[ZYWealthDataItemModel alloc]init];
        model.stockCode = content.value;
        model.stockName  = company.value;
        [items addObject:content.value];
    }
    
    if(items.count > 0){
        if(self.getAllStockCodeBlock){
            self.getAllStockCodeBlock(items);
        }
    }
}

数据解析也是使用第三方库DHxlsReader 不过gitUP上面好像找不到了
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容

  • 比如公司这个月的销售指标下降了,那么你就着手去分析指标下降的原因;同样,如果指标上升了,也去分析原因。 一个公司的...
    飞猪的浪漫阅读 57评论 0 1
  • use WEBSTATS_DBgoALTER DATABASE WEBSTATS_DB SET SINGLE_U...
    XBruce阅读 192评论 0 0
  • 第21章:卓越的计划 李轩握紧了拳头,他知道自己面临着一场巨大的挑战。恐怖组织的存在已经对全球安全形成了威胁,而最...
    东曦之月阅读 91评论 0 3
  • 卷二百一十九,唐纪三十五,肃宗文明武德大圣大宣孝皇帝中之上 至德元载,丙申,公元756年(四) 1、初,李林甫为相...
    荒原苍狼阅读 230评论 0 0
  • 二十一世纪旧体诗词风骚榜[https://www.jianshu.com/c/da968ae2d498] 上榜絮语...
    张成昱阅读 276评论 0 21