Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. General and Desktop
  4. Showing numbers in decimal not scientific notation
Forum Updated to NodeBB v4.3 + New Features

Showing numbers in decimal not scientific notation

Scheduled Pinned Locked Moved Unsolved General and Desktop
41 Posts 9 Posters 31.2k Views 5 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • M Offline
    M Offline
    mostefa
    wrote on last edited by mostefa
    #4

    Hi @tomy

    I don't know if this is what you want, but if you wanna keep only the decimal part of your double you can cast your double to int, you can do something like this :

    (int)(10^6)

    tomyT 1 Reply Last reply
    0
    • K koahnig

      @tomy
      Where do you want to see a fixed number?

      tomyT Offline
      tomyT Offline
      tomy
      wrote on last edited by
      #5

      @koahnig
      The number, "1e+06", will be sent to a QTextStream which has the address of a QString. Then that string will be sent to a lineEdit. and finally LineEdit will show the number in scientific notation.

      1 Reply Last reply
      0
      • Chris KawaC Chris Kawa

        @tomy said in Showing numbers in decimal not scientific notation:

        it shows it this way

        What is "it"? Where do you view the variable? In the debugger? On the standard output? In a text widget? What (if any) function do you use to output the variable?

        tomyT Offline
        tomyT Offline
        tomy
        wrote on last edited by
        #6

        @Chris-Kawa
        I run it in standard mode (ctrl + R).

        Chris KawaC 1 Reply Last reply
        0
        • M mostefa

          Hi @tomy

          I don't know if this is what you want, but if you wanna keep only the decimal part of your double you can cast your double to int, you can do something like this :

          (int)(10^6)

          tomyT Offline
          tomyT Offline
          tomy
          wrote on last edited by
          #7

          @mostefa
          No dear. I don't want it.

          1 Reply Last reply
          0
          • tomyT tomy

            @Chris-Kawa
            I run it in standard mode (ctrl + R).

            Chris KawaC Online
            Chris KawaC Online
            Chris Kawa
            Lifetime Qt Champion
            wrote on last edited by
            #8

            @tomy said in Showing numbers in decimal not scientific notation:

            I run it in standard mode (ctrl + R).

            That's not what I... ugh, nevermind.
            So you say you're using QTextStream. Ok, so you have a code similar to this right?

            QTextStream foo = ...;
            double bar = ...;
            foo << bar;
            

            If that's the case then you can do it in a couple of ways:
            Switch the stream serialization mode for floating numbers to fixed notation:

            QTextStream foo = ...;
            foo.setRealNumberNotation(QTextStream::FixedNotation);
            double bar = ...;
            foo << bar;
            

            or pre-format the number the way you want it and pass the resulting string to the stream:

            QTextStream foo = ...;
            double bar = ...;
            foo << QString::number(bar, 'f');
            
            tomyT 1 Reply Last reply
            3
            • Chris KawaC Chris Kawa

              @tomy said in Showing numbers in decimal not scientific notation:

              I run it in standard mode (ctrl + R).

              That's not what I... ugh, nevermind.
              So you say you're using QTextStream. Ok, so you have a code similar to this right?

              QTextStream foo = ...;
              double bar = ...;
              foo << bar;
              

              If that's the case then you can do it in a couple of ways:
              Switch the stream serialization mode for floating numbers to fixed notation:

              QTextStream foo = ...;
              foo.setRealNumberNotation(QTextStream::FixedNotation);
              double bar = ...;
              foo << bar;
              

              or pre-format the number the way you want it and pass the resulting string to the stream:

              QTextStream foo = ...;
              double bar = ...;
              foo << QString::number(bar, 'f');
              
              tomyT Offline
              tomyT Offline
              tomy
              wrote on last edited by tomy
              #9

              @Chris-Kawa
              What is ...ugh?! I want to learn it! :)

              My code is like this:

              QString s;
              QTextStream (&s) << 12 ;
              lineEdit -> setText(s); // It outputs 12 
              s.clear();
              
              QTextStream (&s) << "ABC";
              lineEdit -> setText(s); // This time it outputs ABC
              
              1 Reply Last reply
              0
              • Chris KawaC Online
                Chris KawaC Online
                Chris Kawa
                Lifetime Qt Champion
                wrote on last edited by
                #10

                12 is not a double, it's an int. 12.0 is a double and 12.0f is a float.
                So anyway, like I said earlier, either

                QString s;
                QTextStream foo(&s);
                foo.setRealNumberNotation(QTextStream::FixedNotation);
                s << 12.0 ; //assuming you still want that double and not int
                lineEdit -> setText(s);
                

                or

                QString s;
                QTextStream (&s) << QString::number(12.0, 'f');
                lineEdit -> setText(s);
                

                but then it's kinda pointless, you can just directly do

                lineEdit -> setText(QString::number(12.0, 'f'));
                

                ...ugh is the sound you can make when you don't have the energy to explain something, so you just skip it altogether ;)

                tomyT 1 Reply Last reply
                2
                • VRoninV Offline
                  VRoninV Offline
                  VRonin
                  wrote on last edited by VRonin
                  #11

                  no need to use QTextStream in that case:

                  lineEdit->setText(lineEdit->locale().toString(1257.147862,'f'));

                  'f' prevents scientific notation, see http://doc.qt.io/qt-5/qstring.html#argument-formats

                  "La mort n'est rien, mais vivre vaincu et sans gloire, c'est mourir tous les jours"
                  ~Napoleon Bonaparte

                  On a crusade to banish setIndexWidget() from the holy land of Qt

                  tomyT 1 Reply Last reply
                  0
                  • VRoninV VRonin

                    no need to use QTextStream in that case:

                    lineEdit->setText(lineEdit->locale().toString(1257.147862,'f'));

                    'f' prevents scientific notation, see http://doc.qt.io/qt-5/qstring.html#argument-formats

                    tomyT Offline
                    tomyT Offline
                    tomy
                    wrote on last edited by
                    #12

                    @VRonin

                    lineEdit->setText(lineEdit->locale().toString(1257.147862,'f'));

                    There is no s in your lineEdit!

                    lineEdit -> setText( // here s should be put!)
                    
                    1 Reply Last reply
                    0
                    • VRoninV Offline
                      VRoninV Offline
                      VRonin
                      wrote on last edited by
                      #13

                      ok, I guess...

                      QString s;
                      s=lineEdit->locale().toString(1257.147862,'f');
                      lineEdit -> setText(s);
                      

                      "La mort n'est rien, mais vivre vaincu et sans gloire, c'est mourir tous les jours"
                      ~Napoleon Bonaparte

                      On a crusade to banish setIndexWidget() from the holy land of Qt

                      1 Reply Last reply
                      1
                      • Chris KawaC Chris Kawa

                        12 is not a double, it's an int. 12.0 is a double and 12.0f is a float.
                        So anyway, like I said earlier, either

                        QString s;
                        QTextStream foo(&s);
                        foo.setRealNumberNotation(QTextStream::FixedNotation);
                        s << 12.0 ; //assuming you still want that double and not int
                        lineEdit -> setText(s);
                        

                        or

                        QString s;
                        QTextStream (&s) << QString::number(12.0, 'f');
                        lineEdit -> setText(s);
                        

                        but then it's kinda pointless, you can just directly do

                        lineEdit -> setText(QString::number(12.0, 'f'));
                        

                        ...ugh is the sound you can make when you don't have the energy to explain something, so you just skip it altogether ;)

                        tomyT Offline
                        tomyT Offline
                        tomy
                        wrote on last edited by tomy
                        #14

                        @Chris-Kawa said in Showing numbers in decimal not scientific notation:

                        QString s;
                        QTextStream (&s) << QString::number(12.0, 'f');
                        lineEdit -> setText(s);
                        

                        I used it. It's fine for doubles but when I calculate ints (e.g., 2+3) it shows 5.000000!!
                        We should make it show the precision only when the result is a double number not an int.

                        kshegunovK 1 Reply Last reply
                        0
                        • tomyT tomy

                          @Chris-Kawa said in Showing numbers in decimal not scientific notation:

                          QString s;
                          QTextStream (&s) << QString::number(12.0, 'f');
                          lineEdit -> setText(s);
                          

                          I used it. It's fine for doubles but when I calculate ints (e.g., 2+3) it shows 5.000000!!
                          We should make it show the precision only when the result is a double number not an int.

                          kshegunovK Offline
                          kshegunovK Offline
                          kshegunov
                          Moderators
                          wrote on last edited by kshegunov
                          #15

                          @tomy said in Showing numbers in decimal not scientific notation:

                          I used it. It's fine for doubles but when I calculate ints (e.g., 2+3) it shows 5.000000!!
                          We should make it show the precision only when the result is a double number not an int.

                          You either calculate a double or an int, can't be both. Anyway, what you probably want is this:

                          double calculationResult = 12.0;
                          QString displayValue = qFuzzyCompare(calculationResult, static_cast<qint64>(calculationResult)) ? QString::number(static_cast<qint64>(calculationResult)) : QString::number(calculationResult, 'f');
                          

                          Read and abide by the Qt Code of Conduct

                          tomyT 1 Reply Last reply
                          1
                          • kshegunovK kshegunov

                            @tomy said in Showing numbers in decimal not scientific notation:

                            I used it. It's fine for doubles but when I calculate ints (e.g., 2+3) it shows 5.000000!!
                            We should make it show the precision only when the result is a double number not an int.

                            You either calculate a double or an int, can't be both. Anyway, what you probably want is this:

                            double calculationResult = 12.0;
                            QString displayValue = qFuzzyCompare(calculationResult, static_cast<qint64>(calculationResult)) ? QString::number(static_cast<qint64>(calculationResult)) : QString::number(calculationResult, 'f');
                            
                            tomyT Offline
                            tomyT Offline
                            tomy
                            wrote on last edited by tomy
                            #16

                            @kshegunov

                            You either calculate a double or an int, can't be both.
                            Anyway, what you probably want is this:

                            How can it be acceptable!? All calculator around the world do calculations on both types. Furthermore, when I write 2.3+4.6, it shows: 6.900000!
                            That is it works fine neither for ints nor for doubles.

                            double calculationResult = 12.0;
                            QString displayValue = qFuzzyCompare(calculationResult, static_cast<qint64>(calculationResult) ? QString::number(static_cast<qint64>(calculationResult)) : QString::number(calculationResult, 'f');
                            

                            Ow my God! Isn't there any simpler way?
                            Please have a look at Windows built-in calculator. See this how simple and nifty shows results.
                            Do you say that behind that Windows' calculator there would be such a long statement just for showing numbers in decimal mode, if it were written by C++/Qt?

                            kshegunovK VRoninV 2 Replies Last reply
                            0
                            • tomyT tomy

                              @kshegunov

                              You either calculate a double or an int, can't be both.
                              Anyway, what you probably want is this:

                              How can it be acceptable!? All calculator around the world do calculations on both types. Furthermore, when I write 2.3+4.6, it shows: 6.900000!
                              That is it works fine neither for ints nor for doubles.

                              double calculationResult = 12.0;
                              QString displayValue = qFuzzyCompare(calculationResult, static_cast<qint64>(calculationResult) ? QString::number(static_cast<qint64>(calculationResult)) : QString::number(calculationResult, 'f');
                              

                              Ow my God! Isn't there any simpler way?
                              Please have a look at Windows built-in calculator. See this how simple and nifty shows results.
                              Do you say that behind that Windows' calculator there would be such a long statement just for showing numbers in decimal mode, if it were written by C++/Qt?

                              kshegunovK Offline
                              kshegunovK Offline
                              kshegunov
                              Moderators
                              wrote on last edited by kshegunov
                              #17

                              @tomy said in Showing numbers in decimal not scientific notation:

                              How can it be acceptable!? All calculator around the world do calculations on both types. Furthermore, when I write 2.3+4.6, it shows: 6.900000!

                              No they do calculation in the widest possible type they support (here it's double) and then display the result as appropriate. Further reading on implicit type promotions in c++ can be found here

                              Ow my God! Isn't there any simpler way?

                              This is a simple if-else statement with the notable exception that it compares floating point values as they should be compared.

                              Do you say that behind that Windows' calculator there would be such a long statement just for showing numbers in decimal mode, if it were written by C++/Qt?

                              Yes, I'm sure of it. It's probably even much longer as windows is actually written in C.

                              Read and abide by the Qt Code of Conduct

                              1 Reply Last reply
                              1
                              • tomyT Offline
                                tomyT Offline
                                tomy
                                wrote on last edited by tomy
                                #18

                                I used this:

                                ss = qFuzzyCompare(expression(),
                                                 static_cast<qint64>(expression()) ?
                                                 QString::number(static_cast<qint64>(expression())) :
                                                 QString::number(expression(), 'f'));
                                 result_box -> setText(ss);
                                

                                ss is a QString.
                                expression() returns an int or double value.
                                result_box is a lineEdit which shows the result of the calculations.

                                I get this error:
                                C:\Users\ME\Documents\Qt\My_First_Calculator\my_first_calculator.cpp:81: error: no matching function for call to 'qFuzzyCompare(double, QString)'
                                QString::number(expression(), 'f'));
                                ^

                                kshegunovK 1 Reply Last reply
                                0
                                • tomyT tomy

                                  I used this:

                                  ss = qFuzzyCompare(expression(),
                                                   static_cast<qint64>(expression()) ?
                                                   QString::number(static_cast<qint64>(expression())) :
                                                   QString::number(expression(), 'f'));
                                   result_box -> setText(ss);
                                  

                                  ss is a QString.
                                  expression() returns an int or double value.
                                  result_box is a lineEdit which shows the result of the calculations.

                                  I get this error:
                                  C:\Users\ME\Documents\Qt\My_First_Calculator\my_first_calculator.cpp:81: error: no matching function for call to 'qFuzzyCompare(double, QString)'
                                  QString::number(expression(), 'f'));
                                  ^

                                  kshegunovK Offline
                                  kshegunovK Offline
                                  kshegunov
                                  Moderators
                                  wrote on last edited by
                                  #19

                                  @tomy said in Showing numbers in decimal not scientific notation:

                                  expression() returns an int or double value.

                                  I'm pretty sure that functions returns a string, not an int, nor a double. You need to convert the string to an actual number if you want to use it as such, e.g. see here.

                                  Read and abide by the Qt Code of Conduct

                                  tomyT 1 Reply Last reply
                                  0
                                  • kshegunovK kshegunov

                                    @tomy said in Showing numbers in decimal not scientific notation:

                                    expression() returns an int or double value.

                                    I'm pretty sure that functions returns a string, not an int, nor a double. You need to convert the string to an actual number if you want to use it as such, e.g. see here.

                                    tomyT Offline
                                    tomyT Offline
                                    tomy
                                    wrote on last edited by tomy
                                    #20

                                    @kshegunov

                                    expression() returns an int or double value.

                                    I'm pretty sure that functions returns a string, not an int, nor a double.

                                    Don't be that sure. :)
                                    I have this method in my code:

                                    double My_First_Calculator::expression()
                                    

                                    But I think this error is of that ss is a QString.

                                    kshegunovK 1 Reply Last reply
                                    0
                                    • tomyT tomy

                                      @kshegunov

                                      You either calculate a double or an int, can't be both.
                                      Anyway, what you probably want is this:

                                      How can it be acceptable!? All calculator around the world do calculations on both types. Furthermore, when I write 2.3+4.6, it shows: 6.900000!
                                      That is it works fine neither for ints nor for doubles.

                                      double calculationResult = 12.0;
                                      QString displayValue = qFuzzyCompare(calculationResult, static_cast<qint64>(calculationResult) ? QString::number(static_cast<qint64>(calculationResult)) : QString::number(calculationResult, 'f');
                                      

                                      Ow my God! Isn't there any simpler way?
                                      Please have a look at Windows built-in calculator. See this how simple and nifty shows results.
                                      Do you say that behind that Windows' calculator there would be such a long statement just for showing numbers in decimal mode, if it were written by C++/Qt?

                                      VRoninV Offline
                                      VRoninV Offline
                                      VRonin
                                      wrote on last edited by
                                      #21

                                      @tomy Did you even try my solution?

                                      "La mort n'est rien, mais vivre vaincu et sans gloire, c'est mourir tous les jours"
                                      ~Napoleon Bonaparte

                                      On a crusade to banish setIndexWidget() from the holy land of Qt

                                      tomyT 1 Reply Last reply
                                      0
                                      • VRoninV VRonin

                                        @tomy Did you even try my solution?

                                        tomyT Offline
                                        tomyT Offline
                                        tomy
                                        wrote on last edited by
                                        #22

                                        @VRonin

                                        Should I use it this way:

                                        QString ss;
                                        ss = result_box -> locale().toString(1257.147862,'f');
                                        QTextStream (&ss) << expression();
                                        result_box -> setText(ss);
                                        

                                        ?

                                        VRoninV 1 Reply Last reply
                                        0
                                        • tomyT tomy

                                          @VRonin

                                          Should I use it this way:

                                          QString ss;
                                          ss = result_box -> locale().toString(1257.147862,'f');
                                          QTextStream (&ss) << expression();
                                          result_box -> setText(ss);
                                          

                                          ?

                                          VRoninV Offline
                                          VRoninV Offline
                                          VRonin
                                          wrote on last edited by
                                          #23

                                          @tomy No, don't use QTextStream you don't need something like stringstream to pass numbers to string.

                                          QString ss;
                                          ss = result_box -> locale().toString(expression(),'f');
                                          result_box -> setText(ss);
                                          

                                          or more concisely, result_box->setText(result_box->locale().toString(expression(),'f'));

                                          "La mort n'est rien, mais vivre vaincu et sans gloire, c'est mourir tous les jours"
                                          ~Napoleon Bonaparte

                                          On a crusade to banish setIndexWidget() from the holy land of Qt

                                          tomyT 1 Reply Last reply
                                          0

                                          • Login

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Categories
                                          • Recent
                                          • Tags
                                          • Popular
                                          • Users
                                          • Groups
                                          • Search
                                          • Get Qt Extensions
                                          • Unsolved