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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • java 取余和取模运算之间的区别「建议收藏」

    java 取余和取模运算之间的区别「建议收藏」转自lee371042https://blog.csdn.net/lee371042/article/details/102553342packageOperator;importjava.math.BigInteger;/***假如有两个数:*amod(b)与a%b,b为正整数,*一种叫a对b取模,另一个叫a对b取余,两种叫法有什么区别呢?*通常情况下,取模运算也叫取余运算,*它们返回的结果都是一个数对另一个数的余数,**区别在于当a是一

  • 行为识别综述

    行为识别综述定义背景难点最新论文最新算法数据集1定义行为识别:行为识别(ActionRecognition)任务是从视频剪辑(2D帧序列)中识别不同的动作,其中动作可以在视频的整个持续时间内执行或不执行。行为识别似乎是图像分类任务到多个帧的扩展,然后聚合来自每帧的预测。尽管图像分类取得了很大的成功,但是视频分类和表示学习依然进展缓慢。2背景2.1方法2.1.1传统方法提取视频区域的局部高维视觉特征,然后组合成固定大小的视频级描述,最后利用分类器(SVM,RF等)进行最终预测2.

  • netty 书籍_pdf怎么把书签变成目录

    netty 书籍_pdf怎么把书签变成目录Netty权威指南第2版带书签目录完整版下载地址:https://pan.baidu.com/s/12h96bKAdKEGXHdqOskK3nw扫码下面二维码关注公众号回复100019获取分享码本书目录结构如下:第1章Java的I/O演进之路1.1I/O基础入门1.2Java的I/O演进1.3总结第2章NIO入门2.1传统的BIO编程2.2伪异步I/O编程2.3NIO编程2.4AIO编程2.54…

  • Odin Inspector 系列教程 — 初识 OdinWindow「建议收藏」

    Odin Inspector 系列教程 — 初识 OdinWindow「建议收藏」笔者以往在使用一些插件的时候经常会看上面这种多炫酷的插件操作界面,常常羡慕不已,如今有了Odin,自己也可以简简单单的实现这些炫酷的效果了,下面笔者就带大家初识OdinWindow。创建一个Window不积跬步无以至千里,我们先从最简单的创建一个Window开始,只需要自定义一类并继承OdinEditorWindow即可publiccl…

  • Chango的数学Shader世界(二十三)漩涡Shader-复数分析(深渊)「建议收藏」

    Chango的数学Shader世界(二十三)漩涡Shader-复数分析(深渊)「建议收藏」目的:我的2D游戏,需要一个有特定感觉的“漩涡shader”。上一节里,我简单实现了这个:但转动有些乏味,它的转动动作是类似这样的:(网图)接下来想让它动起来更加深邃,恐怖。本文先搞了2种效果:(图3,扩散瞳孔)(图4,深渊)抽象分析:前篇的Shader效果之所以看起来乏味,是因为在旋转的时候,像素点的极长(以方块中心为原点极坐标系)并没有改变,只是越接近中心,点的旋转量越小而已。(旋转前后点都在同心圆上)如果我想要深渊有“吃人”的感觉,那么内部的

  • informix最新版本_sql权威指南 pdf

    informix最新版本_sql权威指南 pdf 最让人兴奋的是《informix实用全书》,PDF清晰版091229InformixV11.50.xC6        http://cid-62f8b4120839d1a2.skyd…Informix/2009-12-29InformixV11.50.TC6Windows32bitEnglish(CZ6QHEN)InformixV1…

    2022年10月20日

发表回复

您的电子邮箱地址不会被公开。

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