鱼C论坛

 找回密码
 立即注册
查看: 2549|回复: 3

[已解决]用c语言读写*.csv数据(Excel的一种)结果全为0

[复制链接]
发表于 2019-4-10 17:18:15 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
读取到的数据全都是0,为什么呢大神们?

  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. int main()
  4. {
  5.         FILE *read,*write;
  6.          
  7.         char filename1[100];
  8.         printf("请输入原文件名(请确认文件与程序在同一文件夹,输入时包含文件后缀名):");
  9.         scanf("%s",filename1);
  10.         if((read=fopen(filename1,"r"))==NULL)
  11.         {
  12.                 printf("原文件打开错误!\n");
  13.                 exit(1);
  14.         }
  15.         if((write=fopen("4.csv","w"))==NULL)
  16.         {
  17.                 printf("生成文件打开错误!\n");
  18.                 exit(1);
  19.         }
  20.        
  21.         int i,j;
  22.         double m[10000][2],n[10000][2];
  23.         fseek(read,0L,SEEK_SET);
  24.     for(i=0;i<=9000;i++)//双循环读取*.csv(数据是n行2列的数字)表中数据 ,赋予m数组
  25.         {
  26.                 for(j=0;j<=1;j++)
  27.                 {       
  28.                         fscanf(read,"%f",&m[i][j]);
  29.                         fseek(read,1L,SEEK_CUR);
  30.                
  31.                 }
  32.          }
  33.          for(i=0;i<=9000;i++)//将第一个*.csv表格中两列数据相加输出为第一列,相减输出为第二列
  34.          {
  35.                  n[i][0]=m[i][0]+m[i][1];
  36.                  n[i][1]=m[i][0]-m[i][1];
  37.                  fprintf(write,"%f,%f\n",n[i][0],n[i][1]);
  38.          }
  39.                 
  40.         fclose(read);
  41.         fclose(write);
  42.         printf("完成!");
  43. }
复制代码


最佳答案
2019-4-10 20:47:17
代建成 发表于 2019-4-10 20:26
单双精度不都是%f吗

那是printf,scanf双精度要使用%lf
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-4-10 19:17:09 | 显示全部楼层
m是double型,
你读取时却使用的是
  1.          fscanf(read,"%f",&m[i][j]);
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-4-10 20:26:58 | 显示全部楼层
Croper 发表于 2019-4-10 19:17
m是double型,
你读取时却使用的是

单双精度不都是%f吗
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-4-10 20:47:17 | 显示全部楼层    本楼为最佳答案   
代建成 发表于 2019-4-10 20:26
单双精度不都是%f吗

那是printf,scanf双精度要使用%lf
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-8 10:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表