C++ 解析字符串流的boost单元
boost units库提供了有用的编译时“度量单位”类型检查。它还提供流io操作来序列化单元。但是,我正在努力处理字符串解析位。 例如,以下行:C++ 解析字符串流的boost单元,c++,string,parsing,boost,units-of-measurement,C++,String,Parsing,Boost,Units Of Measurement,boost units库提供了有用的编译时“度量单位”类型检查。它还提供流io操作来序列化单元。但是,我正在努力处理字符串解析位。 例如,以下行: boost::units::quantity<boost::units::si::force> f(2.0 * boost::units::si::newton); std::cout << "Force = " << f << std::endl; 有人能给我举个例子,将这些标准序列化解析回boos
boost::units::quantity<boost::units::si::force> f(2.0 * boost::units::si::newton);
std::cout << "Force = " << f << std::endl;
有人能给我举个例子,将这些标准序列化解析回boost单元吗
// f.parse_string("2.0 N"); or using stream operators??
谢谢 该库不直接支持它 有一个例子可以给我们一些启发: 此示例演示如何实现允许不同 运行时的单元,同时仍保持内部的类型安全 计算
namespace {
using namespace boost::units;
using imperial::foot_base_unit;
std::map<std::string, quantity<si::length> > known_units;
}
quantity<si::length> calculate(const quantity<si::length>& t)
{
return(boost::units::hypot(t, 2.0 * si::meters));
}
int main()
{
known_units["meter"] = 1.0 * si::meters;
known_units["centimeter"] = .01 * si::meters;
known_units["foot"] =
conversion_factor(foot_base_unit::unit_type(), si::meter) * si::meter;
std::string output_type("meter");
std::string input;
while((std::cout << "> ") && (std::cin >> input))
{
if(!input.empty() && input[0] == '#')
{
std::getline(std::cin, input);
}
else if(input == "exit")
{
break;
}
else if(input == "help")
{
std::cout << "type \"exit\" to exit\n"
"type \"return 'unit'\" to set the return units\n"
"type \"'number' 'unit'\" to do a simple calculation"
<< std::endl;
}
else if(input == "return")
{
if(std::cin >> input)
{
if(known_units.find(input) != known_units.end())
{
output_type = input;
std::cout << "Done." << std::endl;
}
else
{
std::cout << "Unknown unit \"" << input << "\""
<< std::endl;
}
}
else
{
break;
}
}
else
{
try
{
double value = boost::lexical_cast<double>(input);
if(std::cin >> input)
{
if(known_units.find(input) != known_units.end())
{
std::cout << static_cast<double>(
calculate(value * known_units[input]) /
known_units[output_type])
<< ' ' << output_type << std::endl;
}
else
{
std::cout << "Unknown unit \"" << input << "\""
<< std::endl;
}
}
else
{
break;
}
}
catch(...)
{
std::cout << "Input error" << std::endl;
}
}
}
}
名称空间{
使用名称空间boost::units;
使用英制::英尺\基础\单位;
std::映射已知的单位;
}
数量计算(常数数量和t)
{
返回(升压::单位::降压(t,2.0*si::米));
}
int main()
{
已知单位[“米”]=1.0*si::米;
已知单位[“厘米]=.01*si::米;
已知_单位[“英尺”]=
换算系数(英尺基础单位::单位类型(),si::米)*si::米;
标准:串输出_类型(“仪表”);
std::字符串输入;
while((std::cout>input))
{
如果(!input.empty()&&input[0]='#')
{
std::getline(std::cin,输入);
}
否则如果(输入=“退出”)
{
打破
}
else if(输入=“帮助”)
{
标准::cout输入)
{
if(已知单位.查找(输入)!=已知单位.结束())
{
输出类型=输入;
标准::cout
namespace {
using namespace boost::units;
using imperial::foot_base_unit;
std::map<std::string, quantity<si::length> > known_units;
}
quantity<si::length> calculate(const quantity<si::length>& t)
{
return(boost::units::hypot(t, 2.0 * si::meters));
}
int main()
{
known_units["meter"] = 1.0 * si::meters;
known_units["centimeter"] = .01 * si::meters;
known_units["foot"] =
conversion_factor(foot_base_unit::unit_type(), si::meter) * si::meter;
std::string output_type("meter");
std::string input;
while((std::cout << "> ") && (std::cin >> input))
{
if(!input.empty() && input[0] == '#')
{
std::getline(std::cin, input);
}
else if(input == "exit")
{
break;
}
else if(input == "help")
{
std::cout << "type \"exit\" to exit\n"
"type \"return 'unit'\" to set the return units\n"
"type \"'number' 'unit'\" to do a simple calculation"
<< std::endl;
}
else if(input == "return")
{
if(std::cin >> input)
{
if(known_units.find(input) != known_units.end())
{
output_type = input;
std::cout << "Done." << std::endl;
}
else
{
std::cout << "Unknown unit \"" << input << "\""
<< std::endl;
}
}
else
{
break;
}
}
else
{
try
{
double value = boost::lexical_cast<double>(input);
if(std::cin >> input)
{
if(known_units.find(input) != known_units.end())
{
std::cout << static_cast<double>(
calculate(value * known_units[input]) /
known_units[output_type])
<< ' ' << output_type << std::endl;
}
else
{
std::cout << "Unknown unit \"" << input << "\""
<< std::endl;
}
}
else
{
break;
}
}
catch(...)
{
std::cout << "Input error" << std::endl;
}
}
}
}