iOS 開發(fā)將數(shù)據(jù)寫入Excel 并且從Excel中讀取數(shù)據(jù)

iOS 開發(fā)將數(shù)據(jù)寫入Excel 并且從Excel中讀取數(shù)據(jù)

1、將數(shù)據(jù)寫入Excel

獲取本地沙河地址
NSString *documentDirectory = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];
/// 獲取當(dāng)前日期
NSString *xlsxName = excelName;
  // 拼接 cache路徑 + 名為xlsxName的文件   注意:該路徑下的文件名一定要和后續(xù)導(dǎo)出的文件名保持一致,否則后續(xù)執(zhí)行導(dǎo)出操作時(shí),讀取不到該文件
NSString *filename =[documentDirectory stringByAppendingPathComponent:xlsxName];
創(chuàng)建excel 使用xlsxwriter 開源庫
lxw_workbook  *workbook  = workbook_new([filename UTF8String]);
lxw_worksheet *worksheet = workbook_add_worksheet(workbook, @"desipot".UTF8String);
創(chuàng)建excel樣式
lxw_format *columnTitleformat = workbook_add_format(workbook);
// 內(nèi)容垂直居中
format_set_align(columnTitleformat, LXW_ALIGN_VERTICAL_CENTER);
// 內(nèi)容水平居中
format_set_align(columnTitleformat, LXW_ALIGN_CENTER);
寫入數(shù)據(jù)
 NSArray *titles = [self getTitls];
    /// 二級標(biāo)題  模型對應(yīng)的字段
    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 ++;
    }
關(guān)閉寫入
int resut = workbook_close(workbook);
if(resut != 0){
    NSLog(@"falied");
}
完整代碼
NSString *documentDirectory = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];
/// 獲取當(dāng)前日期
NSString *xlsxName = excelName;
  // 拼接 cache路徑 + 名為xlsxName的文件   注意:該路徑下的文件名一定要和后續(xù)導(dǎo)出的文件名保持一致,否則后續(xù)執(zhí)行導(dǎo)出操作時(shí),讀取不到該文件
NSString *filename =[documentDirectory stringByAppendingPathComponent:xlsxName];


/// 創(chuàng)建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);
// 內(nèi)容垂直居中
format_set_align(columnTitleformat, LXW_ALIGN_VERTICAL_CENTER);
// 內(nèi)容水平居中
format_set_align(columnTitleformat, LXW_ALIGN_CENTER);
/// 標(biāo)題
NSArray *titles = [self getTitls];
/// 二級標(biāo)題  模型對應(yīng)的字段
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 中的數(shù)據(jù)

獲取本地沙河地址
NSString *paths =   [[NSBundle mainBundle]pathForResource:@"list" ofType:@".xlsx"];
解析數(shù)據(jù)
LAWExcelTool.shareInstance.delegate = self;
[LAWExcelTool.shareInstance parserExcelWithPath:paths];
協(xié)議數(shù)據(jù)返回
- (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);
        }
    }
}

數(shù)據(jù)解析也是使用第三方庫DHxlsReader 不過gitUP上面好像找不到了
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 比如公司這個(gè)月的銷售指標(biāo)下降了,那么你就著手去分析指標(biāo)下降的原因;同樣,如果指標(biāo)上升了,也去分析原因。 一個(gè)公司的...
    飛豬的浪漫閱讀 92評論 0 1
  • use WEBSTATS_DBgoALTER DATABASE WEBSTATS_DB SET SINGLE_U...
    XBruce閱讀 234評論 0 0
  • 第21章:卓越的計(jì)劃 李軒握緊了拳頭,他知道自己面臨著一場巨大的挑戰(zhàn)??植澜M織的存在已經(jīng)對全球安全形成了威脅,而最...
    東曦之月閱讀 134評論 0 3
  • 卷二百一十九,唐紀(jì)三十五,肅宗文明武德大圣大宣孝皇帝中之上 至德元載,丙申,公元756年(四) 1、初,李林甫為相...
    荒原蒼狼閱讀 326評論 0 0
  • 二十一世紀(jì)舊體詩詞風(fēng)騷榜[http://www.itdecent.cn/c/da968ae2d498] 上榜絮語...
    張成昱閱讀 313評論 0 21

友情鏈接更多精彩內(nèi)容