Ce n'est pas un dup exact mais vous trouverez la réponse @ Cubbi de here utile, je parie. Cela suppose spécifiquement une entrée UTC. Boost supporte également la conversion directe d'ISO 8601 en boost::posix_time::from_iso_string
qui appelle boost::date_time::parse_iso_time
, là encore vous devez simplement supprimer le 'Z' final et traiter le TZ comme UTC implicite.
#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() dans mon CRT. Ymmv. –
@Loki, nous n'avons pas besoin d'une balise meta pour attraper toutes les choses qui sont neutres sur le système d'exploitation. S'il vous plaît, arrêtez de recréer l'étiquette. – Charles
@Charles: S'il vous plaît arrêter de changer ma question. J'aurais cependant eu l'indication que je pense que la modification est invalide après la deuxième fois que je l'ai changé. –