文本控件中读出来的科学计数法文本,怎么精确转换成float类型

liuxuwentiger 2015-12-11 09:36:41
MFC对话框窗口上,有一个EDIT控件,里面的数据都是仪器测试出来,以科学计数法记录的数据,怎么把数据转换成精确的浮点数?求各位大侠指点,谢谢了。
...全文
465 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
赵4老师 2015-12-14
  • 打赏
  • 举报
回复
#include <stdio.h>
#include <tchar.h>
TCHAR s[]=_T(
"+1.946778660E+01,+8.948916161E+01,+0,+0\n"
"+1.930291487E+02,+8.921232518E+01,+0,+0\n"
"+2.063480938E+03,+8.135056168E+01,+0,+0\n"
"+4.157431443E+03,+6.557659563E+01,+0,+0\n"
"+5.722808011E+03,+5.061641198E+01,+0,+0\n"
"+6.670965858E+03,+3.889735674E+01,+0,+0\n"
"+7.244019312E+03,+2.993750144E+01,+0,+0\n"
);
TCHAR *p;
double v;
int n,k;
int main() {
    p=s;
    while (1) {
        k=_stscanf(p,_T("%lf%n"),&v,&n);
        _tprintf(_T("k,v,n=%d,%.9lE,%d\n"),k,v,n);
        if (1==k) {
            p+=n;
        } else if (0==k) {
            _tprintf(_T("skip char[%c]\n"),p[0]);
            p++;
        } else {//EOF==k
            break;
        }
    }
    _tprintf(_T("End.\n"));
    return 0;
}
//k,v,n=1,1.946778660E+001,16
//k,v,n=0,1.946778660E+001,16
//skip char[,]
//k,v,n=1,8.948916161E+001,16
//k,v,n=0,8.948916161E+001,16
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=0,0.000000000E+000,2
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=1,1.930291487E+002,17
//k,v,n=0,1.930291487E+002,17
//skip char[,]
//k,v,n=1,8.921232518E+001,16
//k,v,n=0,8.921232518E+001,16
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=0,0.000000000E+000,2
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=1,2.063480938E+003,17
//k,v,n=0,2.063480938E+003,17
//skip char[,]
//k,v,n=1,8.135056168E+001,16
//k,v,n=0,8.135056168E+001,16
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=0,0.000000000E+000,2
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=1,4.157431443E+003,17
//k,v,n=0,4.157431443E+003,17
//skip char[,]
//k,v,n=1,6.557659563E+001,16
//k,v,n=0,6.557659563E+001,16
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=0,0.000000000E+000,2
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=1,5.722808011E+003,17
//k,v,n=0,5.722808011E+003,17
//skip char[,]
//k,v,n=1,5.061641198E+001,16
//k,v,n=0,5.061641198E+001,16
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=0,0.000000000E+000,2
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=1,6.670965858E+003,17
//k,v,n=0,6.670965858E+003,17
//skip char[,]
//k,v,n=1,3.889735674E+001,16
//k,v,n=0,3.889735674E+001,16
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=0,0.000000000E+000,2
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=1,7.244019312E+003,17
//k,v,n=0,7.244019312E+003,17
//skip char[,]
//k,v,n=1,2.993750144E+001,16
//k,v,n=0,2.993750144E+001,16
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=0,0.000000000E+000,2
//skip char[,]
//k,v,n=1,0.000000000E+000,2
//k,v,n=-1,0.000000000E+000,2
//End.
//
洗洗睡去 2015-12-13
  • 打赏
  • 举报
回复
用AfxExtractSubString分割字符串 比如
CString str = "123,-456(/t)7.89";
CString output = "";
则
AfxExtractSubString(output, str, 0, ','); //123
AfxExtractSubString(output, str, 1, ',); //-456
AfxExtractSubString(output, str, 2, '/t'); //7.89
然后_ttof
paschen 2015-12-12
  • 打赏
  • 举报
回复
引用 2 楼 liuxuwentiger 的回复:
[quote=引用 楼主 liuxuwentiger 的回复:] MFC对话框窗口上,有一个EDIT控件,里面的数据都是仪器测试出来,以科学计数法记录的数据,怎么把数据转换成精确的浮点数?求各位大侠指点,谢谢了。
先谢谢版主回复,数据格式如下: +1.946778660E+01,+8.948916161E+01,+0,+0 +1.930291487E+02,+8.921232518E+01,+0,+0 +2.063480938E+03,+8.135056168E+01,+0,+0 +4.157431443E+03,+6.557659563E+01,+0,+0 +5.722808011E+03,+5.061641198E+01,+0,+0 +6.670965858E+03,+3.889735674E+01,+0,+0 +7.244019312E+03,+2.993750144E+01,+0,+0 UNICODE环境,atof不好使啊 [/quote] 用 _ttof 把你数据先以逗号分割,然后调用即可
liuxuwentiger 2015-12-12
  • 打赏
  • 举报
回复
引用 楼主 liuxuwentiger 的回复:
MFC对话框窗口上,有一个EDIT控件,里面的数据都是仪器测试出来,以科学计数法记录的数据,怎么把数据转换成精确的浮点数?求各位大侠指点,谢谢了。
先谢谢版主回复,数据格式如下: +1.946778660E+01,+8.948916161E+01,+0,+0 +1.930291487E+02,+8.921232518E+01,+0,+0 +2.063480938E+03,+8.135056168E+01,+0,+0 +4.157431443E+03,+6.557659563E+01,+0,+0 +5.722808011E+03,+5.061641198E+01,+0,+0 +6.670965858E+03,+3.889735674E+01,+0,+0 +7.244019312E+03,+2.993750144E+01,+0,+0 UNICODE环境,atof不好使啊
oyljerry 2015-12-11
  • 打赏
  • 举报
回复
atof 或者自己解析字符串
没法下载,到这里折腾一把试试。 本文由abc2253130贡献 doc文档可能在WAP端浏览体验不佳。建议您优先选择TXT,或下载源文件到本机查看。 C#(WINFORM)学习 一、 C#基础 基础 类型和变量 类型和变量 类型 C# 支持两种类型:“值类型”和“引用类型”。值类型包括简单类型(如 char、int 和 float 等)、枚举类型和结构类型。引用类型包括类 (Class)类 型、接口类型、委托类型和数组类型。 变量的类型声明 变量的类型声明 每个变量必须预先声明其类型。如 int a; int b = 100; float j = 4.5; string s1; 用 object 可以表示所有的类型。 预定义类型 下表列出了预定义类型,并说明如何使用。 类型 object 说明 所有其他类型的最终 基类型 字符串类型; 字符串是 Unicode 字符序列 8 位有符号整型 16 位有符号整型 32 位有符号整型 64 位有符号整型 示例 object o = null; 范围 string sbyte short int long string s = "hello"; sbyte val = 12; short val = 12; int val = 12; long val1 = 12; -128 到 127 -32,768 到 32,767 -2,147,483,648 2,147,483,647 -9,223,372,036,854,775,808 到 第1页 C#(WINFORM)学习 long val2 = 34L; 到 9,223,372,036,854,775,807 byte ushort 8 位无符号整型 16 位无符号整型 byte val1 = 12; ushort val1 = 12; uint val1 = 12; uint 32 位无符号整型 uint val2 = 34U; ulong val1 = 12; ulong val2 = 34U; ulong 64 位无符号整型 ulong val3 = 56L; ulong val4 = 78UL; float 单精度浮点型 float val = 1.23F;7 位 double val1 = 1.23; double 双精度浮点型 double val2 = ±5.0 × 10?324 ±1.7 × 10 308 0 到 255 0 到 65,535 0 到 4,294,967,295 0 到 18,446,744,073,709,551,615 ±1.5 × 10?45 ±3.4 × 10 38 到 到 4.56D;15-16 布尔型;bool 值或为 真或为假 字符类型;char 值是 一个 Unicode 字符 精确的小数类型, 具有 28 个有效数字 bool val1 = true; bool val2 = false; char val = 'h'; decimal val = bool char decimal DateTime ±1.0 × 10?28 ±7.9 × 10 28 到 1.23M;28-29 变量转换 简单转换: float f = 100.1234f; 可以用括号转换: short s = (short)f 也可以利用 Convert 方法来转换: string s1; s1=Convert.ToString(a); MessageBox.Show(s1); 常用 Convert 方法有: 第2页 C#(WINFORM)学习 C# Convert.ToBoolean Convert.ToByte Convert.ToChar Convert.ToDateTime Convert.ToDecimal Convert.ToDouble Convert.ToInt16 Convert.ToInt32 Convert.ToInt64 Convert.ToSByte Convert.ToSingle Convert.ToString Convert.ToUInt16 Convert.ToUInt32 Convert.ToUInt64 备注 Math 类 常用科学计算方法: C# Math.Abs Math.Sqrt Math.Ro

19,468

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC 图形处理/算法
社区管理员
  • 图形处理/算法社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧