No es un duplicado exacto pero la respuesta de @ Cubbi es here útil, apuesto. Esto asume específicamente la entrada UTC.
Boost también es compatible con la conversión directa de ISO 8601 a través de boost::posix_time::from_iso_string
que llama a boost::date_time::parse_iso_time
, aquí de nuevo simplemente quitaría la 'Z' posterior y trataría el TZ como UTC implícito.
#include <iostream>
#include <boost/date_time.hpp>
namespace bt = boost::posix_time;
const std::locale formats[] = {
std::locale(std::locale::classic(),new bt::time_input_facet("%Y-%m-%d %H:%M:%S")),
std::locale(std::locale::classic(),new bt::time_input_facet("%Y/%m/%d %H:%M:%S")),
std::locale(std::locale::classic(),new bt::time_input_facet("%d.%m.%Y %H:%M:%S")),
std::locale(std::locale::classic(),new bt::time_input_facet("%Y-%m-%d"))};
const size_t formats_n = sizeof(formats)/sizeof(formats[0]);
std::time_t pt_to_time_t(const bt::ptime& pt)
{
bt::ptime timet_start(boost::gregorian::date(1970,1,1));
bt::time_duration diff = pt - timet_start;
return diff.ticks()/bt::time_duration::rep_type::ticks_per_second;
}
void seconds_from_epoch(const std::string& s)
{
bt::ptime pt;
for(size_t i=0; i<formats_n; ++i)
{
std::istringstream is(s);
is.imbue(formats[i]);
is >> pt;
if(pt != bt::ptime()) break;
}
std::cout << " ptime is " << pt << '\n';
std::cout << " seconds from epoch are " << pt_to_time_t(pt) << '\n';
}
int main()
{
seconds_from_epoch("2004-03-21 12:45:33");
seconds_from_epoch("2004/03/21 12:45:33");
seconds_from_epoch("23.09.2004 04:12:21");
seconds_from_epoch("2003-02-11");
}
_mkgmtime() en mi CRT. Ymmv. –
@Loki, no necesitamos una metaetiqueta para capturar todas las cosas que son OS-neutral. Por favor deja de volver a crear la etiqueta. – Charles
@Charles: Por favor, deja de cambiar mi pregunta. Hubiera pensado que tendrías la pista de que la edición no es válida después de la segunda vez que la cambié. –