-2

在我的程序中,我试图用“$876,725.38”这样的钱读取文件,我能够删除逗号和美元符号,我现在正在尝试使用 atof 将字符串转换为双精度,但我现在遇到的问题是在打印MONEYS转换后,我得到了大部分时间之前的所有内容,但有些时间之前少于 6 位的数字在期间之后会打印一位或两位数字。如果有人对此有解决方案,将不胜感激。我是 C++ 新手,需要帮助。谢谢!

主要问题:从字符串转换为双精度,小数点后的数据不打印。

    void readFile()
{
    string line, nuMoney, munney, cents;
    unsigned long dollarSign, period;


    ifstream myfile("MONEY.txt");

    int numLines = countLines("MONEY.txt");
    //cout << "NUMLINES: " << numLines << endl;

    if (!myfile.is_open())
    {
        cout << "ERROR: File could not be opened." << endl;
    }

    for (int i=0; i < numLines-1; i++)
    {
        getline(myfile, line, '\n');
        dollarSign = line.find('$');
        period = line.find('.');

        line.erase (remove(line.begin(), line.end(), ','), line.end()); //remove commas

        munney = line.substr(dollarSign+1);
        //cout << munney << endl;

        //cents = line.substr(period);
        //cout << "Cents: " << cents << endl;

        //double CENTUS = atof(cents.c_str());
        //cout << "CENTUS: " << CENTUS << endl;

        double MONEYS = atof(munney.c_str());
        cout << MONEYS << endl;

        list<double> acct;
        acct.push_back(MONEYS);

    }

}

样本输出:

937380
404261
814158
30218.1
69340.1
479891
517241
7203.55
975619
59219.4
900052
539774
336799
347700
532466
83496.8
4

3 回答 3

1

浮点 (floatdouble)long double不适合存储精确值。它们很棒,因为它们可以很容易地对各种值进行许多不同的数学运算,但是有许多值无法使用 IEEE 浮点数精确表示。简单到0.1无法通过类型准确表达的值,但输入和输出例程通常会四舍五入以使其看起来处理正确。

为了存储十进制完美值,我建议在读入时将值的 2 部分视为单独的整数,根据读入的小数位后的位数转换小数点,然后做一些数学运算来转换这两个部分成一个整数。对于美国货币,该整数的 LSB(最低有效位)可能代表 1 美分(除非需要准确表示小数美分)。类似的方法可用于输出值。

于 2015-03-27T19:15:47.743 回答
0

看起来这是由于浮点值的 cout 流的默认精度:http ://www.cplusplus.com/reference/ios/ios_base/precision/

于 2015-03-27T19:21:59.650 回答
0

您必须告诉输出流您想要点后 2 位的固定精度:

#include <iomanip>
// ...
std::cout << std::fixed << std::setprecision(2) << MONEYS << '\n';
于 2015-03-27T19:25:17.090 回答