- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将电子邮件(日期对象)的接收日期与 JSONObject 中的日期(字符串)进行比较。这两个日期将属于不同时区,相差 1 小时。
我的情况是,我必须在几秒钟内获得它们之间的确切差异,如果差异为 +/- 10 秒,我就会找到匹配项。为此,我决定将两者都转换为“UTC”,然后进行区别。这是我的代码:
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
sdf.setTimeZone(TimeZone.getTimeZone("UTC"));
String MsgDtStr = sdf.format(messagesToBeProcessed.getReceivedDate());
Date MsgDt = sdf.parse(MsgDtStr);
Date ObjDt = sdf.parse((JsonObj.get("date").toString()));
int DiffInSecs = (int) (ObjDt.getTime() - MsgDt.getTime()) / 1000 % 60;
if (DiffInSecs >= -10 && DiffInSecs <= 10) {
System.out.println("Found a match!");
MatchedList.add(i);
}
这似乎给了我正确的结果。应该与 json 对象匹配的邮件匹配。即差异为 +/- 10 秒。但是,当我尝试在上述逻辑之后打印日期和 DiffInSecs 时,我得到如下值:
date in object: 2017-06-22 19:47:25
date in message: 2017-06-22 23:47:30
DiffInSecs: -5
........
date in object: 2017-06-22 17:50:38
date in message: 2017-06-22 21:50:39
DiffInSecs: -1
我发现两个时间相差 4 小时。现在我很困惑我的逻辑是如何运作的。对此有何解释?我解决问题的方法是否正确?
这些是我应该使用的邮件和 jsonobject 的示例日期值,它们应该匹配:(我如何以任何方式实现这一点,而不仅仅是我发布的方法)
messagesToBeProcessed[i].getReceivedDate():2017 年 6 月 22 日星期四 01:03:13 CDT
messagesToBeProcessed[i].getReceivedDate().getTime(): 1498111393000
Obj.get('日期'): 2017-06-22 02:03:03
ObjDt.getTime(): 1498096983000
编辑:
正如 JBNizet 在评论中所指出的,我需要删除 %60
才能获得以秒为单位的精确差异。
好吧,现在我觉得坚持旧的 API 没有意义。现在,我在消息对象中的日期不再像我在上面的结果中发布的那样转换为 UTC。我不确定为什么它以前有效但现在不再有效(欢迎对此进行任何解释/评论)。正如 Hugo 在他的回答中指出的,使用新的 Java.Time API 更好。
希望这个帖子可以帮助人们在未来找到出路。
最佳答案
我不确定您使用的是哪个 Java 版本,但无论如何:旧类(Date
、Calendar
和 SimpleDateFormat
)有lots of problems和 design issues ,并且它们正在被新的日期/时间 API 取代。
如果您使用的是 Java 8,请考虑使用 new java.time API 。更容易,less bugged and less error-prone than the old APIs .
如果您使用的是 Java <= 7,则可以使用 ThreeTen Backport ,Java 8 新日期/时间类的一个很好的向后移植。对于 Android,有 ThreeTenABP (更多关于如何使用它 here )。
下面的代码适用于两者。唯一的区别是包名称(在 Java 8 中是 java.time
,在 ThreeTen Backport(或 Android 的 ThreeTenABP)中是 org. Threeten.bp
),但是类和方法名称相同。
根据 getReceivedDate()
的输出,您的默认时区是 CDT
。但是这些短时区名称(例如 EST
和 CDT
)是 ambiguous and not standard .
新 API 使用 Continent/City
格式的长名称(由 IANA database 使用。因此,CDT
可以位于许多不同的位置,例如美国/芝加哥
或美国/哈瓦那
。您必须首先检查哪一个最适合您的上下文 - 您可以使用 ZoneId.getAvailableZoneIds()
获取所有可用名称的列表。
对于下面的示例,我随机选择了其中一个(美国/芝加哥
),只是为了展示它是如何工作的。我使用 DateTimeFormatter
来解析输入 String
并使用 ZoneId
将其转换为时区。
// parse jsonInput
String jsonInput = "2017-06-22 02:03:03";
// formatter
DateTimeFormatter fmt = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
// parse the input to a LocalDateTime
LocalDateTime dt = LocalDateTime.parse(jsonInput, fmt); // 2017-06-22T02:03:03
// convert it to the EDT timezone (using America/Chicago as it's currently in CDT)
ZonedDateTime z = dt.atZone(ZoneId.of("America/Chicago")); // 2017-06-22T02:03:03-05:00[America/Chicago]
// convert the java.util.Date object to the new API
Date date = new Date(1498111393000L); // using your timestamp = 2017-06-22T06:03:13 UTC
// for Java >= 8, use toInstant method
Instant instant = date.toInstant();
// for Java <= 7, use org.threeten.bp.DateTimeUtils
Instant instant = DateTimeUtils.toInstant(date);
// get the difference between them
long diffSecs = ChronoUnit.SECONDS.between(instant, z);
差异将为 3590 秒 - 这是因为 CDT
(在我的示例中为芝加哥)中的 2017-06-22 02:03:03
等于 UTC 2017-06-22T07:03:03Z
。您的日期(1498111393000 毫秒)等于 UTC 2017-06-22T06:03:13Z
。
在您的代码中,您使用 sdf
解析输入 2017-06-22 02:03:03
,但是 sdf
设置为 UTC(而不是 CDT),导致结果不正确(假设 JSON 输入也在 CDT 中)。
如果要将 JSON 输入转换为 UTC,可以使用 ZoneOffset.UTC
而不是 ZoneId
。
实际上,您必须检查输入是否确实是 UTC 格式,并相应地更改代码(上面的代码假设 JSON 输入是 CDT 格式)。
<小时/>当然,您可以使用 SimpleDateFormat
执行相同的操作:
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
sdf.setTimeZone(TimeZone.getTimeZone("America/Chicago"));
Date jsonDate = sdf.parse("2017-06-22 02:03:03"); // 2017-06-22 02:03:03 in Chicago, or 2017-06-22T07:03:03 in UTC
然后以与您相同的方式计算差异 ((jsonDate.getTime() - date.getTime())/1000
)。结果将与上面相同:3590 秒。
关于java - 比较不同时区的两个日期对象并获取精确的时间差(以秒为单位),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44722209/
我有 2 张 table ; item_in(item_id,unit) item_out(item_id,unit) 现在假设我想知道为每个项目插入了多少个单元,我只是查询 select sum(u
API 浏览器中有 3 个速率限制类别: 如果我使用 Youtube 数据 API(其中跟随 implicit OAuth grant flow)创建客户端 Web 应用程序,我是否仍被限制为总共 1
我正在使用一个 postgresql 表,该表包含许多带有 GEOMETRY(Point, 4326) 的行。使用 ST_SnapToGrid 函数和 DISTINCT 选择,我只根据显示的 map
我对 C++ 和 Cppunit 都很陌生。我正在尝试编译一个小的 cppunit 测试。但是,我没有成功。 qwerty@qwerty:~/chessgame/src$ g++ -Wall Coor
我注意到 REM 单位可用于元素的大小,而不仅仅是字体大小。并且对 HTML 字体大小属性非常有用。 html { font-size:1vw } @media all and (max-width:
我试图在 Shapely 中找到线串的长度(以米为单位),但似乎无法达到预期的结果。几乎可以肯定我在坐标系方面犯了一些错误,但我无法弄清楚。 这是单行的一些简化代码: from shapely.geo
对于大量的物种数据集,我试图计算给定月份集的圆形平均值,例如对于从 3 月到 7 月开花的物种,我想知道开花的平均月份(即 5 月),以及围绕平均值的方差。 给定月份是循环的,因此 12 月到 2 月
我还应该在单元测试中释放对象吗? 我注意到在Apple的“iPhoneUnitTests”示例项目中,设置方法中的对象是[[object alloc] init],但从未在单元测试中的任何地方发布?
我目前正在使用 OpenGL 进行开发,并使用米作为我自己的单位,即 20 厘米宽的三角形为 0.2。然而 OpenGL 似乎对这些数字进行了舍入,最终的形状并不完全符合我的意愿。这在 OpenGL
我的问题与对信号进行频谱分析或将信号放入 FFT 并使用合适的数值包解释结果的物理意义有关, 具体: 获取一个信号,例如时变电压 v(t) 将其放入 FFT 中(您将得到复数序列) 现在取模 (abs
在深入研究代码后,我意识到 Fabricjs Text 对象的 fontSize 是在 PIXELS 中测量的。在我的项目中,有时我需要使用点而不是像素。 当指定单位时,我只在代码中找到一个位置,此片
在我的应用程序中,我尝试使用,RentModel.find({prop_location : { $near : [msg.lat, msg.lng],$maxDistance : 500}},函数(
我正在开发我的第一个 LibGdx (Scene2d + Box2d) 游戏,这对我来说是一个全新的领域,但仍然对一些事情感到有点困惑,尤其是关于单位。已经看到了几种不同的处理方法,但仍然不确定哪种方
我正在寻找一个 MySQL 查询(子查询很好),它将以下列格式获取过去一年中每个订单的单位分布: units_per_order | number_of_orders |
我正在使用 Highcharts生成折线图。 我遇到了 numberFormat 的问题: var test = 15975000; numberFormat(test, 0,',','.'); 结果
我正在尝试创建一些用户定义的类型来表示单位,以便我可以强类型化函数参数。例如,长度为毫米,速度为毫米每秒,加速度为毫米每秒等。 到目前为止我已经这样做了: template struct Value
谁能解释一下最低精度的 ULP 单位?我有如下定义,但还是不清楚 “表示分数时的误差大小与存储的数字大小成正比。ULP 或最小精度单位定义了存储数字时可以获得的最大误差。存储的数字越大,ULP 越大”
我有一张卡片图像,我需要重复它 30 次,每次我想申请一张特定卡片的左侧位置时,它会与卡片重叠,然后再停留在一副牌的位置上。 问题是,当我将左侧位置应用于图像卡片时,它会将相同的左侧位置应用于所有卡片
有没有办法用php代码更改每个滚动条的大小。 说明:当我向下滚动时,它会下降x(50~)像素,我想将x改为20。 编辑:这是我的代码。。。 Excel "; $i=1; wh
我不知道下面的想法是否可行或不能概括它,但我想将每个计算值四舍五入到 100 单位四舍五入。 例子: double x; int x_final; ... if (x<400) x_final=400
我是一名优秀的程序员,十分优秀!