- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我在 stackoverflow 网站上查看了我的答案,我没有得到,所以我把它贴在这里。
我的问题是:
How to compare two time stamp in format
"Month Date hh:mm:ss"
?
我正在用 C 和 C++ 编写程序,时间是可显示的字符串格式。
示例:
time1 = "Mar 21 11:51:20"
time2 = "Mar 21 10:20:05"
我想比较 time1 和 tme2 并找出 time2
是否在之后 time1
并且我需要输出为 true
或 false
,如下所示:
if time2 > time1 then
i need output as 1
or
0 or -1 anything
我使用了 difftime(time2,time1)
,但它返回 time1
和 time2
之间的增量时间 diff
>.
我想检查是否更大。
如有任何帮助,请提前致谢
最佳答案
首先-使用 difftime 进行比较:
你可以简单地使用difftime()
函数比较时间并返回 1
或 -1
如下:
int comparetime(time_t time1,time_t time2){
return difftime(time1,time2) > 0.0 ? 1 : -1;
}
SECOND- 将字符串转换成时间:
如果您难以将 string
转换为 time_t
结构,您可以依次使用两个函数:
char *strptime(const char *buf, const char *format, struct tm *tm);
功能。将字符串转换为 struct tm
示例:要将日期时间字符串 "Mar 21 11:51:20 AM"
转换为 struct tm
,您需要三个合成字符串:
%b : Month name, can be either the full name or an abbreviation
%d : Day of the month [1–31].
%r : Time in AM/PM format of the locale. If not available in the locale time format, defaults to the POSIX time AM/PM format:%I:%M:%S %p
.
time_t mktime (struct tm * timeptr);
将 struct tm*
转换为 time_t
下面是我的示例程序:
#include <stdio.h>
#include <time.h>
int main(void){
time_t t1, t2;
struct tm *timeptr,tm1, tm2;
char* time1 = "Mar 21 11:51:20 AM";
char* time2 = "Mar 21 10:20:05 AM";
//(1) convert `String to tm`:
if(strptime(time1, "%b %d %r",&tm1) == NULL)
printf("\nstrptime failed\n");
if(strptime(time2, "%b %d %r",&tm2) == NULL)
printf("\nstrptime failed\n");
//(2) convert `tm to time_t`:
t1 = mktime(&tm1);
t2 = mktime(&tm2);
printf("\n t1 > t2 : %d", comparetime(t1, t2));
printf("\n t2 > t1 : %d", comparetime(t2, t1));
printf("\n");
return 1;
}
它如你所愿:
$ ./a.out
t1 > t2 : 1
t2 > t1 : -1
要计算两个日期之间的差异,请阅读:How do you find the difference between two dates in hours, in C?
关于c++ - 如何比较格式为 "Month Date hh:mm:ss"的两个时间戳以检查 +ve 或 -ve 值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15555406/
我有两个 javascript 变量(它们来自文本框,所以它们可能被评估为字符串),格式如下:02:30 和 4:45 它们代表小时和分钟。 我想将它们加在一起得到 07:15,但我无法计算出来。 最
我有时间数据库,我想获得时间序列数据的每小时平均值。 示例数据: 1 -1.64 2007-09-29 00:01:09 2 -1.76 2007-09-29 00:03:09 3
我有一个项目,其中使用 Bison 来生成解析器。项目本身是用 SCons 构建的,我的所有代码都是用 C++ 编写的。我一开始就决定将代码分成 3 个主要目录:includes、src 和 test
我正在尝试编写一个将返回当前时间的 SQL 查询,如下所示: HH:MM - HH:MM (+1) 例如如果时间是 14:00,它将返回 14:00 - 15:00 我已经设法做到了以下几点: SEL
关闭。这个问题需要更多focused 。它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 已关闭 3 年前。 Improve this qu
这是我的原始代码- String dateString = "23 Dec 2015 1:4 PM"; Locale locale = new Locale("en_US"); SimpleDateF
我们正在访问允许我们安排日期/时间的 API。我们需要检查预定的事情,这样我们就不会在同一时间重复预订。 API 返回的时间与军事中的 HH 一样。但是,它使用的是 UTC HH。因此,如果我们在下午
final String sourceDate = "05.12.2014 12:17"; final String testDate = "05.12.2014 13:17"; fi
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 7 年前。 Improve t
kk:mm、HH:mm 和 hh:mm 格式有什么区别?? SimpleDateFormat broken = new SimpleDateFormat("kk:mm:ss"); br
在单元格 B239 中,我有 37:15,代表某人完成一项任务所花费的总小时数。在单元格 C239 中,我有以下公式 =INT(B239)*24+小时(B239)+圆形(分钟(B239)/60,2)
我需要在从 HH: 05 到 HH: 59 的时间每小时列出 MAX () 温度 我有 mySQL 代码: SELECT FROM_UNIXTIME(FLOOR(UNIX_TIMESTAMP(
我正在使用 PHP 和 MySQL。如何将格式为 HH:MM AM/PM 的时间转换为 HH:MM:SS 以节省 MySQL 的时间? 最佳答案 使用 strtotime 将其转换为时间戳,然后使用
我想知道是否可以使用 moment.js 将 sql TIME (HH:mm:ss) 转换为 HH:mm。或者也许有一个简单的 JavaScript/jQuery 解决方案? 最佳答案 是的,你可以:
我正在寻找一个正则表达式来匹配不同的时间格式(用于时间跟踪网络应用程序)在 javascript 中。用户可以使用以下格式之一插入时间: h hh:mm hh.mm 我可以很容易地创建一个正则表达式来
我们如何在java中比较日期并获取剩余的可用插槽? Sun 10:00-11:00 Sun 12:00-14:00 Sun 15:00-16:00 那么除了这三个时段之外,我们如何才能获得一天中的所有
如何在 SQL Server 中将 hh:mm:ss 转换为 hh:mm? select Count(Page) as VisitingCount,Page,CONVERT(VARCHAR(8),Da
假设我的时间是 13:45。 现在我想使用 moment.js 将其转换为 13:45:00。 我在做moment('13:45').format('h:m:s'); 但它不起作用。 最佳答案 使用m
我想将时间从 hh:mm:ss 转换为 hh:mm它以 hh:mm:ss 的形式来自数据库(我的 sql)。我尝试了以下代码,但没有得到我想要的。 try { s= Hibernat
我希望这对某人来说是小菜一碟!目前,所有内容的字符串输出均为上午 12:00。 以下来自 MySQL 的代码,格式为 HH:MM:SS (hours_open, hours_close) $get_h
我是一名优秀的程序员,十分优秀!