本章节我们为大家介绍 Perl 语言对时间日期的处理。
Perl中处理时间的函数有如下几种:
接下来让我们看下 localtime() 函数,该函数在没有参数的情况下返回当前的时间和日期。
以下 9 个符号代表不同的时间日期参数:
sec, # 秒, 0 到 61 min, # 分钟, 0 到 59 hour, # 小时, 0 到 24 mday, # 天, 1 到 31 mon, # 月, 0 到 11 year, # 年,从 1900 开始 wday, # 星期几,0-6,0表示周日 yday, # 一年中的第几天,0-364,365 isdst # 如果夏令时有效,则为真
实例演示如下:
以上实例执行输出结果为:
12 六月 星期天
如果直接调用 localtime() ,它返回系统当期设置时区的时间,实例如下:
以上实例执行输出结果为:
时间日期为:Sun Jun 12 11:27:31 2016
函数 gmtime() 与 localtime() 类似,但它返回标准格林威治时间。
以上实例执行输出结果为:
本地时间日期为:Sun Jun 12 11:32:14 2016 GMT 时间日期为:Sun Jun 12 03:32:14 2016
从实例中我们可以看出,中国的时间和格林威治时间相差了8小时。
我们可以使用 localtime() 函数的 9 个时间元素来输出需要制定的格式时间。格式化输出使用 printf() 函数:
以上实例执行输出结果为:
格式化时间:HH:MM:SS 11:35:23
我们可以使用 time() 函数来获取新纪元时间,该函数返回从1970年1月1日起累计的秒数。实例如下:
以上实例执行输出结果为:
从1970年1月1日起累计的秒数为:1465702883
我们可以输出一个我们想要的时间格式:
以上实例执行输出结果为:
当期时间和日期:2017-3-15 12:47:54 昨天时间和日期:2017-3-14 12:47:54
函数 strftime() 可以将时间格式化为我们想要的格式。
下表列出了一些格式化的符号,* 号表示想要依赖本地时间:
| 符号 | 描述 | 实例 |
|---|---|---|
%a |
星期几的简称( Sun..Sat) * | Thu |
%A |
星期几的全称( Sunday..Saturday) * | Thursday |
%b |
月的简称(Jan..Dec) * | Aug |
%B |
月的全称(January..December) * | August |
%c |
日期和时间 * | Thu Aug 23 14:55:02 2001 |
%C |
年份除于100,并取整 (00-99) |
20 |
%d |
一个月的第几天 (01-31) |
23 |
%D |
日期, MM/DD/YY 相等于%m/%d/%y |
08/23/01 |
%e |
一个月的第几天,使用空格填充个位数 ( 1-31) |
23 |
%F | YYYY-MM-DD 的简写类似于 %Y-%m-%d |
2001-08-23 |
%g |
年份的最后两位数 (00-99) |
01 |
%g |
年 | 2001 |
%h |
月的简称 * (和%b选项相同) |
Aug |
%H | 24 小时制 (00-23) |
14 |
%I |
12 小时制 (01-12) |
02 |
%j |
一年的第几天 (001-366) |
235 |
%m |
月 (01-12) |
08 |
%M |
分钟 (00-59) |
55 |
%n |
新行 ('\n') |
|
%p | 显示出AM或PM | PM |
%r |
时间(hh:mm:ss AM或PM),12小时 * | 02:55:02 pm |
%R |
24 小时 HH:MM 时间格式,相等于 %H:%M |
14:55 |
%S |
秒数 (00-61) |
02 |
%t |
水平制表符 ('\t') |
|
%T |
时间(24小时制)(hh:mm:ss),相等于%H:%M:%S |
14:55 |
%u |
ISO 8601 的星期几格式,星期一为1 (1-7) |
4 |
%U |
一年中的第几周,星期天为第一天(00-53) |
33 |
%V |
ISO 8601 第几周 (00-53) |
34 |
%w |
一个星期的第几天(0代表星期天) (0-6) |
4 |
%W |
一年的第几个星期,星期一为第一天 (00-53) |
34 |
%x |
显示日期的格式(mm/dd/yy) * | 08/23/01 |
%X |
显示时间格式 * | 14:55:02 |
%y |
年,两位数 (00-99) |
01 |
%Y |
年 | 2001 |
%z |
ISO 8601与UTC的时区偏移(1 minute=1, 1 hour=100)
|
+100 |
%Z |
当前时区的名称,如"中国标准时间" *
|
CDT |
%% |
% 符号 |
% |
以上实例执行输出结果为:
时间日期 - 2016-06-12 12:15:13 时间日期 - 2016-06-12 04:15:13
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
我想设置一个默认日期,例如实际日期,我该如何设置?还有如何在组合框中设置默认值顺便问一下,date_field_tag和date_field之间有什么区别? 最佳答案 试试这个:将默认日期作为第二个参数传递。youcorrectlysetthedefaultvalueofcomboboxasshowninyourquestion. 关于ruby-on-rails-date_field_tag,如何设置默认日期?[rails上的ruby],我们在StackOverflow上找到一个类似的问
我需要检查DateTime是否采用有效的ISO8601格式。喜欢:#iso8601?我检查了ruby是否有特定方法,但没有找到。目前我正在使用date.iso8601==date来检查这个。有什么好的方法吗?编辑解释我的环境,并改变问题的范围。因此,我的项目将使用jsapiFullCalendar,这就是我需要iso8601字符串格式的原因。我想知道更好或正确的方法是什么,以正确的格式将日期保存在数据库中,或者让ActiveRecord完成它们的工作并在我需要时间信息时对其进行操作。 最佳答案 我不太明白你的问题。我假设您想检查
我的日期格式如下:"%d-%m-%Y"(例如,今天的日期为07-09-2015),我想看看是不是在过去的七天内。谁能推荐一种方法? 最佳答案 你可以这样做:require"date"Date.today-7 关于ruby-检查日期是否在过去7天内,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/32438063/
这个问题在这里已经有了答案:Railsformattingdate(4个答案)关闭4年前。我想格式化Time.Now函数以显示YYYY-MM-DDHH:MM:SS而不是:“2018-03-0909:47:19+0000”该函数需要放在时间中.现在功能。require‘roo’require‘roo-xls’require‘byebug’file_name=ARGV.first||“Template.xlsx”excel_file=Roo::Spreadsheet.open(“./#{file_name}“,extension::xlsx)xml=Nokogiri::XML::Build
我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s
这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Pythonconditionalassignmentoperator对于这样一个简单的问题表示歉意,但是谷歌搜索||=并不是很有帮助;)Python中是否有与Ruby和Perl中的||=语句等效的语句?例如:foo="hey"foo||="what"#assignfooifit'sundefined#fooisstill"hey"bar||="yeah"#baris"yeah"另外,类似这样的东西的通用术语是什么?条件分配是我的第一个猜测,但Wikipediapage跟我想的不太一样。
为什么以下不同?Time.now.end_of_day==Time.now.end_of_day-0.days#falseTime.now.end_of_day.to_s==Time.now.end_of_day-0.days.to_s#true 最佳答案 因为纳秒数不同:ruby-1.9.2-p180:014>(Time.now.end_of_day-0.days).nsec=>999999000ruby-1.9.2-p180:015>Time.now.end_of_day.nsec=>999999998
是否有简单的方法来更改默认ISO格式(yyyy-mm-dd)的ActiveAdmin日期过滤器显示格式? 最佳答案 您可以像这样为日期选择器提供额外的选项,而不是覆盖js:=f.input:my_date,as::datepicker,datepicker_options:{dateFormat:"mm/dd/yy"} 关于ruby-on-rails-事件管理员日期过滤器日期格式自定义,我们在StackOverflow上找到一个类似的问题: https://s
我正在尝试查询我的Rails数据库(Postgres)中的购买表,我想查询时间范围。例如,我想知道在所有日期的下午2点到3点之间进行了多少次购买。此表中有一个created_at列,但我不知道如何在不搜索特定日期的情况下完成此操作。我试过:Purchases.where("created_atBETWEEN?and?",Time.now-1.hour,Time.now)但这最终只会搜索今天与那些时间的日期。 最佳答案 您需要使用PostgreSQL'sdate_part/extractfunction从created_at中提取小时