- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用 perl,我试图估计自文件创建以来的时间。我想将本地时间转换为 unix 时间(纪元),然后取文件的 unix 时间并减去。
我面临的问题是,当我将 localtime 转换为 unixtime 时,它转换不正确!
my $current = str2time (localtime(time));
print $current;
我得到的结果是
2768504400 = Sun, 23 Sep 2057 21:00:00 GMT
2421349200 = Sun, 23 Sep 2046 21:00:00 GMT
我必须以特定日期格式输入 str2time 吗?
最佳答案
你在这里做了一些奇怪的事情 - localtime(time)
需要 - 纪元时间 (time
) 并将其转换为字符串。
然后你把它转换回来。
只需使用 time()
或者更好的是-M
,它告诉你文件多久以前被修改过。 (在几天内,所以你必须乘以)。
例如:
my $filename = "sample.csv";
my $modification = -M $filename;
print $modification * 84600;
但如果您真的想花时间再将其转换回来 - 您需要查看 localtime(time)
如何返回结果。
如果你这样做:
print localtime(time);
你得到:
5671624811542661
因为 localtime
正在列表上下文中进行评估,因此返回一个值数组。 (无需解析即可使用)。
my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) =
localtime(time);
如果您在标量上下文中执行此操作,它会返回一个表示时间的字符串:
print "".localtime(time);
给予:
Thu Sep 24 16:09:33 2015
但请注意 - 这可能会有所不同,具体取决于您当前的语言环境。这就是可能为什么str2time
正在做一些奇怪的事情——因为它对并不总是适用的格式做出了某些假设。最大的问题是:
When both the month and the date are specified in the date as numbers they are always parsed assuming that the month number comes before the date. This is the usual format used in American dates.
您可能最好使用 Time::Piece
和 strftime
来获得固定格式:
例如
use Time::Piece;
print localtime(time) -> strftime ( "%Y-%m-%d %H:%M:%S" );
注意 - Time::Piece
重载 localtime
,因此您可以(相当)透明地实际使用它。当然,那么你也可以也这样做:
print localtime(time) -> epoch;
并且不用大惊小怪地来回转换。
关于Perl 将本地时间转换为 unix(纪元)时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32764240/
我将时间存储在 64 位整数中,格式为 20110103101419(即表示 2011-01-03 10:14:19)。如何将其转换为自 1970 年以来的秒数? 最佳答案 我的 C 有点生疏,但看看
我正在生成一个包含过去二十四小时事件 gnuplot 的图表,但时间轴看起来非常糟糕,因为它试图在最后一天每五分钟拟合一次长数字。 gnuplot 有什么方法可以将 x 轴视为纪元时间,并每隔一小时左
我当前正在使用 django 并输出 unix 纪元的日期(以秒为单位)。如何在 unix epoch 中使用 jquery time ago ? 我看到这个例子:2015 年 1 月 10 日 Ja
我在 Google Apps 脚本中将字符串转换为日期对象时遇到一些问题。 我的日期采用以下格式,来自第三方 API: 2013-01-17T17:34:50.507 我正在尝试将其转换为日期对象:
我使用一个库,该库使用以下结构来定义开始时间戳,如下所示。 struct SYSTEMTIME { /** year */ WORD year; /** month *
使用 perl,我试图估计自文件创建以来的时间。我想将本地时间转换为 unix 时间(纪元),然后取文件的 unix 时间并减去。 我面临的问题是,当我将 localtime 转换为 unixtime
我正在使用具有以下响应的 API: { dt: 1474664400, temp: { day: 51.93, min: 46.62, max: 53.53, nigh
我正在从 API 获取估计公交车到达时间的时间戳作为时间戳/纪元:1536589019000。如果我访问类似 this 的网站我得到了适当的格式: 2018 年 9 月 10 日星期一上午 7:16:
我使用的 API 将时间返回为 Unix 时间 (1424952512) 到目前为止,我可以使用将 unix 时间转换为 NSDate func timeStamp(unixTime: Double)
@Data public class SampleDate { private Date revisiondate; } @RequestMapping("/date") public Resp
我在论坛中搜索了我的问题,但一无所获。 :(这个日期时间转换让我发疯。 我尝试将毫秒纪元转换为日期时间。我在互联网上找到了这个方法: private DateTime TimeFromUnix
我有一个 dateTime 变量,我想将它转换为纪元的十进制值。 如何才能做到这一点? 我尝试使用: seconds-from-duration($time, xs:dateTime('1970-01
如何获取纪元中的当前日期值,即自 1970-1-1 以来经过的天数。我需要 unix shell 脚本中的解决方案。 最佳答案 Unix Date 命令将以纪元时间显示 命令是 date +"%s"
这个问题在这里已经有了答案: Convert from date to epoch-Oracle (3 个答案) 关闭 9 个月前。 在使用 Oracle SQL 获取 unix 纪元时间戳方面,有
你能解释一下下面这句话吗,这让我很困惑。1.迭代2.梯度下降步骤3.纪元4.批量大小。 最佳答案 在神经网络术语中: 一个epoch = 所有训练样本的一次前向传递和一次反向传递 批量大小 = 一次前
我在 PostgreSQL 中有一个字符串 "2016-10-25T00:14:30.000"。 我想将时间戳转换为整数,例如:1477354441 我想为该值添加自定义分钟数,例如147735444
我想从 Postgres 获取数据。有一个类型为 timestamp without timezone 的列。简单的 SELECT 返回我格式化的日期,但我只想要以毫秒为单位的时间戳。我如何在 SQL
我的文件包含格式为“[dd.mm.yyyy.] 文本值”的多行。我需要将其转换为“Unix 纪元 | 文本值”。我尝试使用 awk 来执行此操作,但似乎找不到正确的命令例如,如果文件是: [30.08
我的一个表中的一列是 DATE,目前它会自动填充该行创建时间的时间戳。时间戳看起来像 2013-02-10 19:56:12。无论如何,我可以自动使用 unix 纪元为其添加时间戳吗?我希望这是有道理
我需要将时区感知 date_range (TimeStamps) 转换为 UNIX 纪元值,以便在外部 Javascript 库中使用。 我的做法是: # Create localized test
我是一名优秀的程序员,十分优秀!