Ich habe einen Float-Wert, der in einen std::string
eingegeben werden muss. Wie konvertiere ich von Float zu String?
float val = 2.5;
std::string my_val = val; // error here
Verwenden Sie string streams :
std::ostringstream ss;
ss << myFloat;
std::string s(ss.str());
Wenn Sie mit Boost zufrieden sind, ist lexical_cast <> eine bequeme Alternative:
std::string s = boost::lexical_cast<std::string>(myFloat);
Effiziente Alternativen sind z. FastFormat oder einfach die C-Style-Funktionen.
Ab C++ 11 bietet die Standard-C++ - Bibliothek die Funktion std::to_string(arg)
mit verschiedenen unterstützten Typen für arg
.
Sie können eine Vorlage definieren, die nicht nur mit Doubles funktioniert, sondern auch mit anderen Typen.
template <typename T> string tostr(const T& t) {
ostringstream os;
os<<t;
return os.str();
}
Dann können Sie es für andere Typen verwenden.
double x = 14.4;
int y = 21;
string sx = tostr(x);
string sy = tostr(y);
Wichtig:
.__ Lesen Sie die Notiz am Ende.
Schnelle Antwort :
Verwenden Sie to_string()
. (verfügbar seit c ++ 11)
Beispiel:
#include <iostream>
#include <string>
using namespace std;
int main ()
{
string pi = "pi is " + to_string(3.1415926);
cout<< "pi = "<< pi << endl;
return 0;
}
führen Sie es selbst aus: http://ideone.com/7ejfaU
Diese sind ebenfalls verfügbar:
string to_string (int val);
string to_string (long val);
string to_string (long long val);
string to_string (unsigned val);
string to_string (unsigned long val);
string to_string (unsigned long long val);
string to_string (float val);
string to_string (double val);
string to_string (long double val);
Wichtige Notiz:
Wie @Michael Konečný zu Recht darauf hingewiesen hat, ist die Verwendung von to_string()
bestenfalls riskant, was sehr wahrscheinlich zu unerwarteten Ergebnissen führt.
Von http://de.cppreference.com/w/cpp/string/basic_string/to_string :
Bei Gleitkommatypen kann
std::to_string
zu unerwarteten Ergebnissen führen, da die Anzahl der signifikanten Stellen in der zurückgegebenen Zeichenfolge Null sein kann (siehe Beispiel).
Der Rückgabewert kann erheblich von dem abweichen, wasstd::cout
standardmäßig gedruckt wird, siehe Beispiel .std::to_string
verwendet für Formatierungszwecke das aktuelle Gebietsschema und daher gleichzeitige Aufrufe vonstd::to_string
von Mehrere Threads können zu einer teilweisen Serialisierung von Aufrufen führen.C++17
stelltstd::to_chars
als Gebietsschema-unabhängiger mit höherer Leistung bereit Alternative.
Der beste Weg wäre, stringstream
als andere zu verwenden, wie zum Beispiel @dcp in seine Antwort .:
Dieses Problem wird im folgenden Beispiel veranschaulicht:
Führen Sie das Beispiel selbst aus: https://www.jdoodle.com/embed/v0/T4k
#include <iostream>
#include <sstream>
#include <string>
template < typename Type > std::string to_str (const Type & t)
{
std::ostringstream os;
os << t;
return os.str ();
}
int main ()
{
// more info : https://en.cppreference.com/w/cpp/string/basic_string/to_string
double f = 23.43;
double f2 = 1e-9;
double f3 = 1e40;
double f4 = 1e-40;
double f5 = 123456789;
std::string f_str = std::to_string (f);
std::string f_str2 = std::to_string (f2); // Note: returns "0.000000"
std::string f_str3 = std::to_string (f3); // Note: Does not return "1e+40".
std::string f_str4 = std::to_string (f4); // Note: returns "0.000000"
std::string f_str5 = std::to_string (f5);
std::cout << "std::cout: " << f << '\n'
<< "to_string: " << f_str << '\n'
<< "ostringstream: " << to_str (f) << "\n\n"
<< "std::cout: " << f2 << '\n'
<< "to_string: " << f_str2 << '\n'
<< "ostringstream: " << to_str (f2) << "\n\n"
<< "std::cout: " << f3 << '\n'
<< "to_string: " << f_str3 << '\n'
<< "ostringstream: " << to_str (f3) << "\n\n"
<< "std::cout: " << f4 << '\n'
<< "to_string: " << f_str4 << '\n'
<< "ostringstream: " << to_str (f4) << "\n\n"
<< "std::cout: " << f5 << '\n'
<< "to_string: " << f_str5 << '\n'
<< "ostringstream: " << to_str (f5) << '\n';
return 0;
}
ausgabe :
std::cout: 23.43
to_string: 23.430000
ostringstream: 23.43
std::cout: 1e-09
to_string: 0.000000
ostringstream: 1e-09
std::cout: 1e+40
to_string: 10000000000000000303786028427003666890752.000000
ostringstream: 1e+40
std::cout: 1e-40
to_string: 0.000000
ostringstream: 1e-40
std::cout: 1.23457e+08
to_string: 123456789.000000
ostringstream: 1.23457e+08
Sie können std :: to_string in C++ 11 verwenden
float val = 2.5;
std::string my_val = std::to_string(val);
Wenn Sie sich Sorgen um die Leistung machen, lesen Sie die Bibliothek Boost :: lexical_cast .
Verwenden Sie std::to_chars
, sobald Ihre Standardbibliothek dies bereitstellt:
std::array<char, 32> buf;
auto result = std::to_chars(buf.data(), buf.data() + buf.size(), val);
if (result.ec == std::errc()) {
auto str = std::string(buf.data(), result.ptr - buf.data());
// use the string
} else {
// handle the error
}
Die Vorteile dieser Methode sind:
Leider ist std::to_string
für Gleitkommazahlen von begrenztem Nutzen, da er die feste Darstellung verwendet, kleine Werte auf Null rundet und lange Zeichenfolgen für große Werte erzeugt, z.
auto s1 = std::to_string(1e+40);
// s1 == 10000000000000000303786028427003666890752.000000
auto s2 = std::to_string(1e-40);
// s2 == 0.000000
C++ 20 erhält möglicherweise eine komfortablere std::format
-API mit denselben Vorteilen wie std::to_chars
, wenn der P0645 - Standardvorschlag genehmigt wird.
Dieses Tutorial gibt eine einfache, aber elegante Lösung, die ich abschreibe:
#include <sstream>
#include <string>
#include <stdexcept>
class BadConversion : public std::runtime_error {
public:
BadConversion(std::string const& s)
: std::runtime_error(s)
{ }
};
inline std::string stringify(double x)
{
std::ostringstream o;
if (!(o << x))
throw BadConversion("stringify(double)");
return o.str();
}
...
std::string my_val = stringify(val);