C语言操作Excel表格

来源:互联网 发布:mac放电影有杂音 编辑:程序博客网 时间:2024/05/17 08:49

http://blog.csdn.net/u011944141/article/details/38043155

上网查找了好多的资料发现C语言不能操作Execl表格,说是比较用C++语言好操作,想了解更多请点此链接:C++操作Excel表格

接下来介绍下一位学长介绍给我的方法,比较粗俗,但还是挺实用的。


第一步:先实用C语言创建*.xls的后缀文件,之后把这个文件当做普通的txt文件打开来操作。

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


具体的示例如下代码:

[cpp] view plaincopy
  1. #include <stdio.h>  
  2.   
  3. void writeExcel(void ) {  
  4.       
  5.     FILE *fp = NULL;  
  6.     int t;  
  7.     char ch;  
  8.   
  9.     fp = fopen("F:\\test.xls""w");  
  10.       
  11.     for (int i = 0; i < 10; i++) {  
  12.         printf("please input:");  
  13.         scanf("%d %c", &t, &ch);  
  14.         fprintf(fp, "%d\t%c\n", t, ch);  
  15.     }  
  16.     fclose(fp);  
  17.   
  18. }  
  19.   
  20. int main() {  
  21.   
  22.     writeExcel();  
  23.   
  24.     return 0;  
  25. }  


输入数据:


运行结果:


表格里的数据:


c语言或者php按writeExcel()函数来操作的,建议在使用标准输入前,先把输入缓存区清空,免得得到的结果不是期望的,清空办法如此:setbuf(stdin,NUL); 还有其他方法,建议大家多去网站搜去,且自己亲自试验。

假如把上边的文件名F:\\test.xls 改成F:\\test.csv 的话,此时等数据写完,可以单击右键使用”写字板“的方法打开,打开得到按行("\n")分割,每行里每个单元格是按逗号(”,“)分割的。示例如下:
c语言操作csv.csv 的表格使用默认方式为wps或Excel打开,内容如下:


c语言操作csv.csv 的表格使用写字板的方式打开,内容如下:

通过这么一对比,其实它csv里边就是这么存储的.故可以这么推测理解Excel表格里的格式(个人见解,仅供学习参考)。


最近学习了php语言,面向对象的语言还是牛,有直接操作表格的函数,或者是类。建议学习一下php直接操作表格csv格式,这种方式比较通用。(链接:php操作csv表格)


0 0
原创粉丝点击