mysql有函数做转换

perl也有

time  localtime gmtime

要将字符串时间转换成epoch time可以使用Date::Calc

#!/usr/bin/perl

use strict;
use Date::Calc qw(Mktime);
use Data::Dumper;
my $time = Mktime('2011','05','25','11','05','12');
print localtime($time) . " ";

print localtime(time()) . " ";

************************************************

本文和大家重点讨论一下Perl时间处理函数的概念,Perl能在绝大多数操作系统运行,可以方便地向不同操作系统迁移,并且Perl借取了C、 sed、awk、shellscripting以及很多其他程序语言的特性。

Perl时间处理函数

表示日期的方式多种多样:

“18Jan1973″,”18/01/1973″,”01/18/1973″,”Jan181973″,”18-01-73″ ,”18-01-1973″,”01/73″,其中一些格式意思不清(如”01-06-1973″是表示6月1日呢,还是表示1月6日呢?)如果不规定日期的表示形式,是很难处理的。
想了解”18Jan1973″和”6Sep1950″之间的区别,须要把它们转换为数字表示。Unix内部运用纪元秒表示时间。日期和时间加起来表示之自格林威志时间1970年1月1日午夜时分(纪元)到当前时刻之间的秒数。”18Jan1973″(假定为午夜时分)的纪元秒为96163200。在该系统中,午夜表示一天的开始时刻。
让我们生成一个日期通过Perl中提供的gmtime函数,你可以自己来验证这点。给定一个用以表示自从纪元以来的秒数的整数,通过gmtime函数可以计算出代表相应的日期和时刻,例如:
Perl-le‘printscalargmtime96163200′
ThuJan1800:00:001973
调用gmtime()函数,你会得到一系列值的列表,包括时,分,秒,日期,月份,年份等等。
Perl-le‘printjoin(”,”,gmtime96163200)’
0,0,0,18,0,73,4,17,0
前面3个0分别表示秒,分,时。小时是从0-23,故下午是12时往后。第4个数表示该月中的天数(本例中为18号)。第5个数表示月份,从0开始(代表 1月份)。之所以从0开始,是因为月份对应着月份数组的下标:
@months=qw(JanFebMarAprMayJunJulAugSepOctNovDec);$month=(gmtime96163200)[4];#“Jan”
年份(本例中为73)的表示有点特殊。它并不是年份的最后两位数字。它表示从1900年开始的年份。为什么要这样表示呢?这是因为C语言就是这样处理的。 Perl试图使得其库和系统调用尽量接近操作系统的处理方式。

所以,如果你想输出4位数的年份,表示如下:
$year=(gmtime96163200)[5]+1900;
如果你不了解这种处理方式,就会制造出Y2K疑问,你也许会这样写:
$year=“19″.(gmtime96163200)[5];
#出错!2000年将变为19100
对于gmtime()函数的返回值还没有介绍完,还有4,17,和0这3个数。它们分别表示一星期中的第几天(星期日为0),一年中的第几天(0表示一年中的第一天),以及能不能采用夏时制(表示不采用,正数表示采用,负数表示不可知)。

Perl中的time()函数返回以纪元秒形式表示的当前日期和时间。如果你打算把它转换为字符串,就可运用gmtime()和 localtime()函数:$now=localtime(time());
($sec,$min,$hour,$day,$mon,$year,$wday,$yday,$isdst)=localtime(time());
如果调用localtime()或gmtime()时不带参数,它将自己调用time()
$now=localtime();
($sec,$min,$hour,$day,$mon,$year,$wday,$yday,$isdst)=localtime();

Perl时间处理函数中多见的日期和时间操作

如果你打算计算两个时刻之间的时间段,只需将它们转换为相应的纪元秒,然后两数相减即可:
$difference_in_seconds=$later_datetime-$earlier_datetime;
要把秒转换为分,时,或天数,只须要分别将它们除以60,3600和86400即可:
$difference_in_minutes=$difference_in_seconds/60;
$difference_in_hours=$difference_in_seconds/3600;
$difference_in_day=$difference_in_seconds/86400;

反过来做,你也可以回答如下疑问:”4天后是几号?”:
$then=time()+86400*4;
printscalarlocaltime$then;
它给出的答案精确到秒。例如,如果4天后的纪元秒值为932836935,你可以输出日期的字符串如下;
SatJul2411:23:171999
如果你打算输出那个日期的午夜时分(如”SatJul2400:00:001999″)运用如下模块:$then=$then-$then%86400;#去掉那个日期的尾巴
类似地,你可以用四舍五入法,输出最靠近午夜时分的日期:
$then+=43200;#addonhalfaday
$then=$then-$then%86400;#truncatetotheday

如果你的时区距离GMT为相差偶数个小时,这就管用了。并不是所有的时区都是很容易处理的。你所真实须要的是在你自己的时区内计算纪元秒,而不是在 GMT中计算。
Perl中的名为Time::Local的模块,可以提供两个函数timelocal()和timegm()。其返回值同localtime()和 gmtime()一样。
useTime::Local;
$then=time()+4*86400;
$then=timegmlocaltime$then;
#localepochseconds$then-=$then%86400;
#truncatetotheday
$then=timelocalgmtime$then;
#backtogmtepochseconds
printscalarlocaltime$then,“ ”。

Perl时间处理函数中日常生活所用的日期和时间的表示

你已经级掌握了时,分,年等值的意思,也了解了纪元秒的意思。而日常生活中的日期和时间是用字符串来表示的,你怎样才能把日常所用的日期和时间串格式转换成纪元秒呢?
要领之一是写出语法分析小程序,该要领灵活而高速:
useTime::Local;
@months{qw(JanFebMarAprMayJun
JulAugSepOctNovDec)}=(0..11);
$_=“19Dec199715:30:02″;
/(dd)s+(w+)s+(d+)s+(d+):(d+):(d+)/
ordie“Notadate”;
$mday=$1;
$mon=exists($months{$2})?$months{$2}:die“Badmonth”;
$year=$3-1900;
($h,$m,$s)=($4,$5,$6);
$epoch_seconds=timelocal($s,$m,$h,$mday,$mon,$year);
一个更通用些的要领,是从CPAN安装Date::Manip模块。

useDate::Manip;
$epoch_seconds=UnixDate(”19Dec199715:30:02″,”s”);
留心,由于Date::Manip是个大模块,运用该模块时,将会添加你的程序的启动时间。其中一个原由是Date::Manip将对多种不同的格式执行识别,如:
“today”
“now”
“firstsundayinapril2000″
“3:15,today”
“3:15pm,firstsundayinapril2000″
“2000/01/1809:15″DateManipulation
2036,2037,2038,…,1901?!

大多数C程序把纪元秒存为有符号整数,可表示正的和负的日期,但计算机存储器所表示的整数大小是有限的,用有限的位数来表示秒。这就是说,我们在计算纪元秒时,所表示的日期是有限定的。
确切的限度取决于你的机器所能表示的整数的位数。Perl最多以32位的长度存储整数。粗略地讲,有一位用来表示正负号,其余31位来表示数。如果8位,你可以存储的最大数是255,即2的8次方减1。故Perl中所存储的32位符号数中的最大数为:
print2**31-1,“ ”;
2147483647
这个数字对应了哪个日期呢?
printscalar(gmtime2**31-1),“ ”;
TueJan1903:14:072038
在那个时刻的1秒之后会发生什么呢?
printscalar(gmtime2**31),“ ”;
FriDec1320:45:521901
对于32位有符号整数来说,2**31太大了。它”翻卷过去了”,其符号位被置为负号,因而成为了所能表示的最大负数。这对应于1970年开始时刻之前的秒的最大值。
其结果说明了什么呢?你不能存储gmtime(2**31)之前或gmtime(2**31-1)之后的以纪元秒表示的日期。
你可千万不要想不开,这可不是什么大疑问。如果你要用到32位有符号整数表示的纪元秒以外的时间,你只须要改动你的表示方式,你可从CPAN中找到不少日期模块,其中的Date::Calc和Date::Manip很可能是功能最强的两个模块。
这两个模块运用自己的日期表示方式,以防止Y1901-Y2038的限定。Date::Manip运用罗马历法,从公元0000到公元9999。 Date::Calc也运用罗马历法,可表示的年份从1到32767。

总结

Perl时间处理函数中对于在1902-2037范围内的日期和时期表示,把它们转换为纪元秒,要存取这些数,你只需运用整数算术运算,gmtime()和localtime()函数,以及标准的Time::Local模块。如果要对该范围以外的日期执行计算或者要分析某特殊的日期格式,你可以运用CPAN中的Date::Manip和Date::Calc模块。

perl将字符串时间转换成 epoch time相关推荐

  1. C语言基础:时间转换成字符串 strftime的代码

    将内容过程中经常用的一些内容段做个记录,下边内容段是关于C语言基础:时间转换成字符串 strftime的内容,希望能对大伙有一些用处. #include <stdio.h> #includ ...

  2. 将Json转换过来的带T的字符串格式的时间转换成正常时间,并通过指定格式输出

    java中时间接受Json转换时间格式很讨厌,因为json转换的时间带有"T",导致转换时间出错.我提供了下面方法可以转换时间并传出指定格式时间: /*** 将Json转换过来的带 ...

  3. 微信小程序时间转换成时间戳、获取当前时间戳、获取当前时间、时间戳加减

    时间转换成时间戳 var sTime = "2020-10-22 10:22:22"; var timestamp = Date.parse(new Date(sTime )); ...

  4. c语言字符为0和1,//C语言:将一个由字符0和1组成的表示二进制数的字符串,转换成相应的十进制数返回。...

    //函数fun:将一个由字符0和1组成的表示二进制数的字符串,转换成相应的十进制数返回. #include #pragma warning (disable:4996) #define N 16 /* ...

  5. 关于把字符串整数转换成整数的程序

    前几天去了先锋商泰面试,在面试时做了一个把输入的整数(例如:4238)重新排序成2348输出的题目. 由于自己没有准备充分,只是把功能写出来了.后来没有拿到offer. 今天在看<剑指offer ...

  6. 字符串日期 转换成 需要的格式的 字符串日期(超强)

    字符串日期 转换成 需要的格式的 字符串日期 调用:dateformat(String pattern,Object date, boolean ifNullGetNow): 参数1:patern:你 ...

  7. Java将16进制字符串,转换成字符串

    Java将16进制字符串,转换成字符串 前段时间遇到同事给了我一串16进制的字符串,让我把它给转成正常的字符串. 16进制字符串: c8:ed:cc:bd:d5:eb 转换后正常的字符串: 软探针 解 ...

  8. JAVA CST时间 转换成Date

    Mybatis中处理Oracle时间类型是个比较麻烦的问题,特别是需要用到时间做比较的,可参考以下代码与思路: 格式化CST时间 SimpleDateFormat sdf = new SimpleDa ...

  9. mysql 格林时间转换_格林时间转换成正常时间

    uscdbmt@rac1:~> date +%s 1414741902 oracle中怎么把这个1414741902转换成正常时间格式 select Numtodsinterval(141474 ...

最新文章

  1. MySQL开发医药管理系统_java Web开发医药后台管理系统mysql版本源代码下载,支持中英文...
  2. Keil C语言数据类型,KeilC的指针类型
  3. 解决RecyclerView在ScrollView中会置顶它上面的控件
  4. 敏捷个人实践第18次活动:选择朋友
  5. ML/DL之预测分析类:利用机器学习算法进行预测分析的简介、分析、代码实现之详细攻略
  6. 主成分分析和因子分析及其在R中的…
  7. Ansi、Unicode、UTF8字符串之间的转换和写入文本文件
  8. react学习(32)----onref
  9. 接口_简单get接口_第一个接口
  10. python如何爬取网站所有目录_用python爬虫爬取网站的章节目录及其网址
  11. python机器学习库sklearn——线性回归
  12. 有必要买吗_婴儿床有必要买吗 婴儿床有用吗
  13. spark rdd详解一(rdd入门)
  14. 几款Android 应用自动化测试工具
  15. 磊科Netcore路由器无线无缝中继(桥接)设置方法
  16. ibm tivoli_Tivoli Access Manager信任关联拦截器(TAI ++)
  17. 路由器和交换机的区别?
  18. 宿主机与开发板网络共享
  19. Oracle基础操作
  20. 2018-1-4 Javascript实例演示:

热门文章

  1. tidb 架构 ~Tidb学习系列(5)
  2. 十个Android Material Design库
  3. 解除Xcode中Miss File的警告
  4. Oracle SQL (2):SQL Fundamentals(Day II)
  5. [论文泛读] Dynamic placement of virtual machines for managing sla violations (IM, 2007)
  6. Gevent Tutorial
  7. 为避免攻击,研究员把严重的比特币漏洞详情焐了两年
  8. 动手拆解众筹明星产品安全智能锁KeyWe后,发现它不安全且无解
  9. linux Redhat6.5 中 编译安装apache
  10. java多线程 - 线程通信