Учитывая дату и время ввода (в строковом формате), я пытаюсь получить для нее время эпохи, используя функции time
, приведенные в ctime
, например mktime
. Преобразование даты эпохи time_t
обратно к дате и времени приводит к дате и времени на один час меньше, чем оригинал. Я провел несколько дискуссий, в которых говорится, что может быть корректировка одного часа в случае летнего времени. Вот код:Работа с летним временем - C++
//sample strptime program.
#include <iostream>
#include <ctime>
#include <string>
using namespace std;
long parseTime(string time) {
cout << "Time entered = " << time << endl;
long timeSinceEpoch;
struct tm t;
if(time.find("/") != string::npos) {
//format of date is mm/dd/yyyy. followed by clock in hh:mm (24 hour clock).
if(strptime(time.c_str(), "%m/%e/%Y %H:%M", &t) == NULL) {
cout << "Error. Check string for formatting." << endl;
}
} else if(time.find("-") != string::npos) {
//format of date is yyyy-mm-dd hh:mm:ss (hh in 24 hour clock format).
cout << "I am here." << endl;
if(strptime(time.c_str(), "%Y-%m-%e %H:%M:%S", &t) == NULL) {
cout << "Error. Check string for formatting of new date." << endl;
}
}
cout << "Details of the time structure:" << endl;
cout << "Years since 1900 = " << t.tm_year << endl;
cout << "Months since January = " << t.tm_mon << endl;
cout << "Day of the month = " << t.tm_mday << endl;
cout << "Hour = " << t.tm_hour << " Minute = " << t.tm_min << " second = " << t.tm_sec << endl;
timeSinceEpoch = mktime(&t);
time_t temp = mktime(&t);
cout << "Time since epoch = " << timeSinceEpoch << endl;
cout << "Reconverting to the time structure:" << endl;
struct tm* t2 = localtime(&temp);
cout << "Details of the time structure:" << endl;
cout << "Years since 1900 = " << t2->tm_year << endl;
cout << "Months since January = " << t2->tm_mon << endl;
cout << "Day of the month = " << t2->tm_mday << endl;
cout << "Hour = " << t2->tm_hour << " Minute = " << t2->tm_min << " second = " << t2->tm_sec << endl;
return timeSinceEpoch;
}
int main(int argc, char *argv[]) {
string date, t;
cout << "Enter date: " << endl;
cin >> date;
cout << "Enter time: " << endl;
cin >> t;
struct tm time;
string overall = date + " " + t;
long result = parseTime(overall);
cout << "Time in date + time = " << overall << " and since epoch = " << result << endl;
return 0;
}
Основная сложность вход: Дата: 2013-03-11 время: 04:41:53
Мои вопросы (ы):
1. Проверка tm_idst
flag возвращает ненулевое значение, что указывает на то, что DST действует. Однако, как я узнаю, о чем говорится в часовом поясе?
2. Указанная выше метка времени может не быть записана в том же часовом поясе, в котором я находился. Есть ли способ указать часовой пояс, чтобы флаги tm_idst
были правильно установлены?
3. Как мне работать с DST, когда я не знаю, в какой временной зоне была записана метка времени?
Получение временной зоны зависит от вашей операционной системы и библиотеки C, нет стандартного или независимого от платформы способа ее получения. Например, в Linux с glibc имеется дополнительное поле-член в структуре 'tm', называемой' tm_zone', которая представляет собой строку C-стиля, содержащую аббревиатуру часового пояса. –
@Joachim: Я попробовал опцию 'tm_zone', но, похоже, ее там нет. Так что в основном, я просто получаю время с эпохи, переконвертируюсь в 'struct tm', и если есть разница в часах, добавьте к ней 3600 секунд? Это единственный вариант, с которым я имею дело с DST? – Sriram
комментарий - если вы принимаете «вид» ISO-дат, то правильный формат ввода - YYYY-MM-DD (т.е. 4 + 2 + 2 ** всегда ***) - так что синтаксический анализ для этого - '% Y-% m-% d', формат% e в теории принимает ведущее место для дат с одной цифрой, тогда как [ISO всегда ожидает две цифры за месяц и год] (http://en.wikipedia.org/wiki/ ISO_8601). – Petesh