将用科学表示法表示的字符串转换为浮点和双精度
Convert string represented in scientific notation to float and double
所以我正在进行这个项目,我必须读取一个CSV文件,该文件包含用科学符号表示的数字。到目前为止,我所做的是读取每个数字,然后将该数字转换为字符串,然后用字符串流将其转换为双精度,但我不确定这是否是正确的方法。任何建议/建议都会有所帮助!
double temp;
istringstream in(line); //line is the string which contains the number, ex: 3.30144800e+03
in >> temp;
arr[w++] = temp;
您可以使用std::atof
将字符串转换为双精度
istringstream in(line);
double value(atof(in.str().c_str()));
或者,您可以简单地将替身从缓冲区中流出。。。
double value;
in >> value;
相关文章:
- 如何防止 c++ 在从浮点型转换为双精度型(不适用于 IO)时添加额外的小数?
- 正在将csv文件读取为双精度矢量
- 我可以信任表示整数的浮点或双精度来保持精度吗
- 如何在C++中的同一函数中使用字符串和双精度
- 特征::矩阵<双精度,1,3> 结构类型函数中的返回类型函数
- 检查是否以特定精度给出双精度
- 转换函数,将 std::数组的双精度作为参数或双精度作为参数单独转换
- C 字符串返回字符串的整数/双精度/长整型值
- 为什么将双精度转换为 int 似乎在第 16 位数字之后将其四舍五入?
- 有没有办法构造一个 constexpr 函数来获取双精度的位表示
- 双精度表示循环加值
- 使用具有整数表示和 ULP 的混叠正确比较双精度
- 使用定点表示法将双精度转换为字符串,没有尾随零和机智的冲刺
- 将用科学表示法表示的字符串转换为浮点和双精度
- IEEE-754浮点、双精度和四精度是否保证-2、-1、-0、0、1、2的精确表示
- C++双精度/浮点数的内部表示
- 双精度的精确二进制表示形式
- 双精度和基点的表示
- 将表示小数的 int 转换为双精度的正确方法是什么
- 浮点-如果一个实数可以用双精度表示,我如何编写一个返回true的C++函数