- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我不想在 for 循环中逐日迭代。我创建了一个 Boost ptime
代表我本地时间的一天,例如“2012-01-01 00:00:00”。 (德国)
目前看起来像这样 (ptime start_t, ptime end_t):
for( posix_time::ptime i = start_t; i < end_t; i += gregorian::days(1) ) {
...
}
日期 25.10.2009 有 23 小时,因为在夏令时之间切换。但是命令 gregorian::days(1)
增加了 24 小时。
有没有人有一个很好的解决方案来通过涉及时区而不生成我自己的时区数据库来逐日迭代?
最佳答案
对于简单的一天迭代,您可以使用day_iterator
。但是,据我所知,boost 的公历日期系统与夏令时无关(夏令时是时间 的属性,而不是日期 的属性)。同样,Posix 时间系统“定义了一个非调整时间系统”。我认为本地时间系统适合您的任务。
例子:
#include <boost/date_time.hpp>
int main()
{
using namespace boost;
// POSIX time zone string for Germany
//local_time::time_zone_ptr zone(
// new local_time::posix_time_zone("CET-1CEST,M3.5.0,M10.5.0/3") );
// load from a database
local_time::tz_database db;
db.load_from_file("path_to_boost/libs/date_time"
"/data/date_time_zonespec.csv");
local_time::time_zone_ptr zone = db.time_zone_from_region("Europe/Berlin");
local_time::local_date_time ldt =
local_time::local_sec_clock::local_time(zone);
posix_time::ptime pt = posix_time::second_clock::local_time();
while(true)
{
ldt += gregorian::days(1);
pt += gregorian::days(1);
std::cout << "local_date_time: " << ldt << '\n';
std::cout << "ptime: " << pt << '\n';
std::cin.ignore();
}
}
注意:我不知道如何从用户/系统的设置中获取时区,也无法找到 POSIX 时区字符串的可靠来源。有 boost documentation加上 wikipedia 所说的内容,但最好您自己检查一下。
感谢Matt Johnson指出 POSIX 时间字符串中的错误并通过数据库提供替代解决方案。
关于c++ - 使用 ptime 逐日迭代,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19584478/
我想更改结果中每天的日期。怎么可能 类似的例子:在哪里REPLY_dATE 在“2017-03-17 12:00:00 AM”和“2017-03-17 4:00:00 PM”之间我想替换=====20
我想要获取过去一周至少登录一次的用户数量,但我希望每天独立计算,因此按周数分组是行不通的。 我的 crm_login_info 表结构如下所示: user_id (INT) | login_time
我是一名优秀的程序员,十分优秀!