c语言处理excel表格_c语言一般文件的处理过程

c语言处理excel表格_c语言一般文件的处理过程1写excel是.csv后缀,跳跃间隔符是‘\t’ FILE*fp; fp=fopen(“./test.csv”,”w”);//写 for(i=0;i<4;i++) fprintf(fp,”%c,%d,%d\n”,chy[i],data[i],d2); fclose(fp);2读指定位置读数,如倒序读数,从末尾向前读数!先看代码!倒序读最后一行的数据#include<bits/stdc++.h>#define

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

思路来源:https://blog.csdn.net/hongzhen91/article/details/57422897

1 写

.csv 是 excel 后缀,跳跃间隔符是 ‘,’

	FILE *fp ;
	fp = fopen("./test.csv","w") ; // 写 
	for (i=0 ; i<4 ; i++)
		fprintf(fp,"%c,%d,%d\n", chy[i], data[i], d2) ;
	fclose(fp);

c语言处理excel表格_c语言一般文件的处理过程

2 读

指定位置读数,如倒序读数,从末尾向前 ( 向着开头 ) 读数!

先看 代码!

倒序读 最后一行的数据

#include<bits/stdc++.h> 
#define num 20
using namespace std;

void writeExcel()
{ 
   
	char chy[4]={ 
    'x' ,'a' ,'h','w' }, ch, t;
	int data[4]={ 
    1 , 3 , 6 ,9	}, d1 = -1, d2 = 5;
	int i ;
	FILE *fp ;
	fp = fopen("./test.csv","w") ; // 写 
	for (i=0 ; i<4 ; i++)
		fprintf(fp,"%c,%d,%d\n", chy[i], data[i], 5) ;
	fclose(fp);
	
	cout << "读:" << endl; 
	fp = fopen("./test.csv","r") ; // 读 
	cout << "d1 = " << d1 << endl;
	cout << "ftell(fp) = " << ftell(fp) << endl;
	fseek(fp, 0L, 2); // 末尾 
	cout << "ftell(fp) = " << ftell(fp) << endl << endl;
	
	fseek(fp, -3L, 1); // 向前移动 3L 
	cout << "ftell(fp) = " << ftell(fp) << endl;
	fscanf(fp, "%d", &d1); // 5
	cout << d1 << endl;
	cout << "ftell(fp) = " << ftell(fp) << endl << endl;
	
	fseek(fp, -3L, 1);
	cout << "ftell(fp) = " << ftell(fp) << endl;
	fscanf(fp, "%d", &d1); // 9
	cout << d1 << endl;
	cout << "ftell(fp) = " << ftell(fp) << endl<< endl;
	
	fscanf(fp, "%c", &ch); // 9后面的',' 
	cout << ch << endl;
	cout << "ftell(fp) = " << ftell(fp) << endl<< endl;
	
	fseek(fp, -4L, 1);
	cout << "ftell(fp) = " << ftell(fp) << endl;
	fscanf(fp, "%c", &ch); // w 
	cout << ch << endl;
	cout << "ftell(fp) = " << ftell(fp) << endl<< endl;
	
	fclose(fp);
}

int  main()
{ 
   					
	writeExcel()  ;	
	
	system("pause"); 
	return 0;
}
 

c语言处理excel表格_c语言一般文件的处理过程 c语言处理excel表格_c语言一般文件的处理过程

结果分析可知

首先数据是:%c + ‘,’ + %d + ‘\n’ …
1

字节数总共 29(0 ~ 28),可见数据一共 4 行,每行字节数是 7
第 1 行,0 ~ 6
第 2 行,7 ~ 13
第 3 行,14 ~ 20
第 4 行,21 ~ 27
第 5 行,28 是文本结尾 feof(fp)

2
%c ‘,’ %d ‘\n’ 所占字节都是 1L

字符 w , 9 , 5 , 换行符 \n
指针位置 21 22 23 24 25 26 27

3
顺序读数据
很容易忘了加上 &

fscanf(fp, "%c,%d,%d\n", &ch, &d1, &d2);

逆序读
读完一个数,跳了 1L,再向前跳 3L 才是前一个数

fscanf(fp, "%d\n", &d2);
fseek(fp, -3L, 1);//从当前位置 向着开头的方向移动3L字节
fscanf(fp, "%d\n", &d2);

4
csv 文本结尾是 另开辟一行!
当从头读 或 遍历 数据时,会遍历到最后的 “空行”,具体情况要注意代码细节的不同

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/179230.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • scope 前缀开头的方法

    scope 前缀开头的方法

    2021年11月7日
    57
  • ROS安装报错 sudo: rosdep:找不到命令

    ROS安装报错 sudo: rosdep:找不到命令安装ROS时初始化rosdep过程中,执行到:sodurosdepinit报错:sudo:rosdep:找不到命令原因:没有安装python-rosdep这个包解决办法:sudoapt-getinstallpython-rosdep然后重新执行:sudorosdepinitrosdepupdate…

    2022年6月17日
    222
  • mysql8msi安装教程(数据库mysql安装教程)

    来看这篇文章的肯定是小白,好巧,我也是。。。。。。。废话不多说,先去官网(https://dev.mysql.com/downloads/mysql/)下载mysql。(国外网址,页面可能较慢)往下拉等页面跳转之后,开始选择下载接着下载。。。。ok,下载阶段结束,去安装吧。打开安装程序,同意安装协议。来到这里选择默认,一路傻瓜next;我们选择…

    2022年4月11日
    43
  • 如何使用手机免费将PDF转Word还不限页数

    如何使用手机免费将PDF转Word还不限页数手机如何将PDF转换成Word?有时一些PDF资料需要修改才能使用,电脑端的修改已经很复杂了,更何况手机端安装软件和使用都更困难,而且有一些PDF文档本身就是扫描版无法进行修改,那么我们就只能将PDF转成Word后再编辑。目前一些能搜索的免费转换工具大多都付费,就算免费使用的也是很多限制,比如只能转换前3页或前5页,那么如何免费将手机里的PDF转换成Word还不限制页数呢?下面分享一个简单好用的方法,只需要三步就能轻松完成转换。第一步,首先打开手机的浏览器,输入speedpdf进行搜索,一般搜索结果第一

    2022年4月29日
    103
  • 我离职了[通俗易懂]

    我离职了[通俗易懂]傻瓜,我们江湖再见

    2022年7月25日
    9
  • java中的策略模式(策略模式java)

    前言当代码中出现多重if-else语句或者switch语句时。弊端之一:如果这样的代码出现在多处,那么一旦出现需求变更,就需要把所有地方的if-else或者switch代码进行更改,要是遗漏了某一处,那么程序就会出错。弊端之二:代码逻辑难以理解。卫语句卫语句的使用,并不能改变前言说的弊端:一旦需求更改,需要修改所有使用更改需求的if-else代码块。不过使用卫语句可以让自己或者代码…

    2022年4月18日
    55

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号