【问题标题】:Read double using fscanf使用 fscanf 读取双精度
【发布时间】:2013-07-25 00:09:40
【问题描述】:

我想从文本文件中读取双精度 例如 31 39.9316476397222 116.113516352222

我都试过了,都不行。我只能读取前几个十进制数字,例如39.93164 但不是 39.9316476397222 有谁知道为什么?谢谢!

int NodeID;
double _lat,_long;
fscanf (pFile, "%d %lf %lf", &NodeID,&_lat,&_long);
printf ("I have read: %d %f %f\n", NodeID,_lat,_long);

fscanf (pFile, "%d %lf %lf", &NodeID,&_lat,&_long);
printf ("I have read: %d %lf %lf\n", NodeID,_lat,_long);

【问题讨论】:

  • 请阅读手册了解printf 的作用。

标签: c++ c file scanf


【解决方案1】:

我认为这些数字被正确读取。您的问题在于您的打印输出,这使您认为您没有完整的数字。请记住,printf 通常只输出小数点后的几位数字。

我建议你这样做:

  1. 在您的printf 调用中,使用如下格式说明符:“%.20f”。它告诉printf 输出小数点后20位。
  2. 请记住,无论您使用什么浮点,floatdoublelong double,它的精度和分辨率都是有限的。熟悉浮点数及其工作原理和表示方式。

【讨论】:

  • "%.20f" 有效。谢谢。我知道 float、double 和 long double 之间的区别
  • @dykw:知道你的scanf 已经在工作了;问题是(现在和将来)以 2 为底的浮点数和以 10 为底的实数不是同一组。你不能用浮点数表示很多很多实数;甚至是精度有限的实数。
【解决方案2】:

根据fscanf man page,你应该使用%lf for double :

f, e, g(浮点数):一系列十进制数字,可选地包含一个小数点,可选地前面有一个符号(+ 或 -),可选地后跟一个 e 或 E 字符和一个十进制整数 (或 strtod 支持的其他一些序列)。 符合 C99 的实现也支持以 0x 或 0X 开头的十六进制浮点格式。

【讨论】:

  • 正确答案,使用 "%f" 我们会收到警告:格式 "%f" 需要类型 "float",但参数 3 的类型为 "double"
  • 值得注意的是,如果您使用 printf("%lf") 输出,如果尝试将其读取为 fscanf("%f"),fscanf 会给您带来垃圾结果。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-06-16
  • 2023-03-13
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多