C语言操作EXCEL文件(读写)

本文主要介绍通过纯C语言进行EXCEL的读写操作:

  • C语言读操作
  • C语言写操作
  • 一、写操作

    第一步:单纯C语言写入Excel文件只能是.xls或者.csv的后缀文件,它们可以通过Notepad++等记事本软件当做txt文件打开。

    需要注意的是:当对*.xls文件写入或者读取之后,再打开Excel文件时会弹出格式兼容的提示窗口,因为这样的C语言操作Excel文件是当文本文件打开操作的,所以会忽略原有格式,但是不影响,点击“是(Y)”即可,如下图所示:

    格式兼容性提示

    第二步:对表格的处理,使用C语言打开表格后,文件指针指向整个表格的第1行第1列。 
    如果要给它的下一个同行单元格(第1行第2列)写数据,使用”\t” ; 
    如果要给它的下一个同列单元格(第2行第1列)写数据,使用”\n” 。

    具体代码如下:

    void writeExcel()
    {
        char chy[4]={ 'x' ,'a' ,'h','w' } ;
        int data[4]={ 1 , 3 , 6 ,9  };
        int i ;
        FILE *fp = NULL ;
        fp = fopen("G:\\Desktop\\test.xls","w") ;
        for (i=0 ; i<4 ;i++)
            fprintf(fp,"%c\t%d\n",chy[i],data[i] ) ;
        fclose(fp);
    }
    void main()
    {                   
        writeExcel()  ; 
    }
    运行结果

 

二、读操作

读取文件

 

原文地址: https://blog.csdn.net/hongzhen91/article/details/57422897

 

 

  • 11
    点赞
  • 84
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C语言可以通过使用第三方库或者手动操作文件来实现Excel文件读写。以下是两种方法的介绍: 方法一:使用第三方库 1.1 使用libxls库来读取Excel文件 步骤一:下载libxls库 在http://sourceforge.net/projects/libxls/ 上下载libxls库并解压。 步骤二:安装libxls库 打开命令行窗口,进入解压后的文件夹,执行以下命令: ./configure make sudo make install 步骤三:创建程序文件 创建一个新的C程序文件,例如“excel_read.c”。 步骤四:编写代码 在程序文件中添加以下代码: #include <stdio.h> #include <stdlib.h> #include "libxls/xls.h" int main(int argc, char **argv) { xlsWorkBook* pWB; xlsWorkSheet* pWS; xlsCell* pCell; int i, j; if(argc < 2) { printf("Usage: %s filename.xls\n", argv[0]); return 0; } pWB = xls_open(argv[1], "UTF-8"); if (pWB == NULL) { printf("Error opening file %s\n", argv[1]); return 1; } pWS = xls_getWorkSheet(pWB, 0); if (pWS == NULL) { printf("Error opening worksheet\n"); return 1; } for(i=0; i<=pWS->rows.lastrow; i++) { for(j=0; j<=pWS->rows.lastcol; j++) { pCell = xls_cell(pWS, i, j); if (pCell != NULL && pCell->str != NULL) { printf("%s\t", pCell->str); } else { printf("\t"); } } printf("\n"); } xls_close(pWB); return 0; } 该代码用于读取Excel文件中的数据并输出到控制台。 步骤五:编译和运行程序 在命令行窗口中执行以下命令: gcc -o excel_read excel_read.c -lxlsreader ./excel_read filename.xls 其中,“filename.xls”是要读取的Excel文件名。 1.2 使用libxl库来写入Excel文件 步骤一:下载libxl库 在http://www.libxl.com/ 上下载libxl库并解压。 步骤二:安装libxl库 打开命令行窗口,进入解压后的文件夹,执行以下命令: ./configure make sudo make install 步骤三:创建程序文件 创建一个新的C程序文件,例如“excel_write.c”。 步骤四:编写代码 在程序文件中添加以下代码: #include <stdio.h> #include "libxl.h" int main() { BookHandle book = xlCreateBook(); SheetHandle sheet = xlBookAddSheet(book, "Sheet1"); int i, j; for(i=0; i<10; i++) { for(j=0; j<10; j++) { xlSheetWriteNum(sheet, i, j, i*j, 0); } } xlBookSave(book, "output.xls"); xlBookRelease(book); return 0; } 该代码用于创建一个Excel文件并写入一些数据。 步骤五:编译和运行程序 在命令行窗口中执行以下命令: gcc -o excel_write excel_write.c -lxl ./excel_write 程序会将生成的Excel文件保存为“output.xls”。 方法二:手动操作文件 2.1 打开Excel文件 可以使用标准C库中的fopen函数来打开Excel文件,例如: FILE* fp = fopen("filename.xls", "rb"); 其中,“rb”表示以二进制模式打开文件。 2.2 读取Excel文件 可以使用标准C库中的fread函数来读取Excel文件中的数据,例如: char buffer[1024]; int readSize = fread(buffer, 1, sizeof(buffer), fp); 其中,“buffer”是用于存储读取数据的缓冲区,“readSize”是实际读取数据的大小。 2.3 写入Excel文件 可以使用标准C库中的fwrite函数来写入数据到Excel文件,例如: char buffer[] = "Hello, world!"; fwrite(buffer, 1, sizeof(buffer), fp); 其中,“buffer”是要写入的数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值