1. ホーム
  2. c++

[解決済み] 精度や小数点以下の桁数を指定して、floatを文字列に変換できますか?

2022-11-25 22:08:04

質問

C++でfloatを文字列に変換する際、精度や小数点以下の桁数を指定するにはどうしたらよいでしょうか。

例えば 3.14159265359 -> "3.14"

どのように解決するのですか?

典型的な方法としては stringstream :

#include <iomanip>
#include <sstream>

double pi = 3.14159265359;
std::stringstream stream;
stream << std::fixed << std::setprecision(2) << pi;
std::string s = stream.str();

参照 固定

固定浮動小数点表記を使用する

を設定します。 floatfield の書式フラグを設定します。 str ストリームから fixed .

いつ floatfield が設定されている場合は fixed に設定されている場合、浮動小数点値は固定小数点表記で書かれます。 精度フィールド ( precision ) で、指数部を持たない。

であり セット精度 .


については 技術的な目的のための変換 XML や JSON ファイルにデータを格納するような、技術的な目的のための変換を行うために、C++17 では to_chars 関数のファミリーを定義しています。

準拠したコンパイラがあると仮定すると(執筆時点では不足していますが) このようなものが考えられます。

#include <array>
#include <charconv>

double pi = 3.14159265359;
std::array<char, 128> buffer;
auto [ptr, ec] = std::to_chars(buffer.data(), buffer.data() + buffer.size(), pi,
                               std::chars_format::fixed, 2);
if (ec == std::errc{}) {
    std::string s(buffer.data(), ptr);
    // ....
}
else {
    // error handling
}