Python时间处理-dateutil模块

dateutil模块主要有两个函数,parser和rrule。

其中parser是根据字符串解析成datetime,而rrule则是根据定义的规则来生成datetime。

安装

直接用easy_install或pip在线安装

easy_install python-dateutil
pip install python-dateutil

1、 parser

parser是根据字符串解析成datetime,字符串可以很随意,可以用时间日期的英文单词,可以用横线、逗号、空格等做分隔符。
没指定时间默认是0点,没指定日期默认是今天,没指定年份默认是今年。

>>> from dateutil.parser import parse

>>> parse("2018-10-21")
datetime.datetime(2018, 10, 21, 0, 0)

>>> parse("20181021")
datetime.datetime(2018, 10, 21, 0, 0)

>>> parse("2018/10/21")
datetime.datetime(2018, 10, 21, 0, 0)

>>> parse("10-21")
datetime.datetime(2018, 10, 21, 0, 0)

>>> parse("10/21")
datetime.datetime(2018, 10, 21, 0, 0)

只有月日时,parser会将分隔符前面的数字解析为月份,后面的为日
当有年份时,在前面的月份超出范围时,会自动判断哪个是月哪个是日

>>> parse("3/8")
datetime.datetime(2018, 3, 8, 0, 0)

>>> parse("8/3")
datetime.datetime(2018, 8, 3, 0, 0)

>>> parse("3-8")
datetime.datetime(2018, 3, 8, 0, 0)

>>> parse("8-3")
datetime.datetime(2018, 8, 3, 0, 0)

>>> parse("21/10")
ValueError: month must be in 1..12

>>> parse("3/8/2018")
datetime.datetime(2018, 3, 8, 0, 0)

>>> parse("8/3/2018")
datetime.datetime(2018, 8, 3, 0, 0)

>>> parse("2018/3/8")
datetime.datetime(2018, 3, 8, 0, 0)

>>> parse("3/15/2018")
datetime.datetime(2018, 3, 15, 0, 0)

当前面的月份超过12时,parser会自动识别月和日
>>> parse("15/3/2018")
datetime.datetime(2018, 3, 15, 0, 0)

分隔符改成"-"也一样
>>> parse("15-3-2018")
datetime.datetime(2018, 3, 15, 0, 0)

但是当年份放在前面时,只能按年-月-日的顺序
>>> parse("2018/15/3")
ValueError: month must be in 1..12

当分隔符为逗号时,只有月-日时,要把月放在前面
有年份时,年份要放在后面

>>> parse("3,15")
datetime.datetime(2018, 3, 15, 0, 0)

只识别到了前面的日,月将本月11月作为默认月
>>> parse("15,3")
datetime.datetime(2018, 11, 15, 0, 0)

>>> parse("3,15,2018")
datetime.datetime(2018, 3, 15, 0, 0)

>>> parse("2018,3,15")
ValueError: ('Unknown string format:', '2018,3,15')

parser还可以识别英文的月、日

>>> parse("Mar 15")
datetime.datetime(2018, 3, 15, 0, 0)

没有空格也可以
>>> parse("Mar15")
datetime.datetime(2018, 3, 15, 0, 0)

>>> parse("15 Mar")
datetime.datetime(2018, 3, 15, 0, 0)

>>> parse("Mar 1st")
datetime.datetime(2018, 3, 1, 0, 0)

>>> parse("Mar 15 2018")
datetime.datetime(2018, 3, 15, 0, 0)

>>> parse("2018 Mar15")
datetime.datetime(2018, 3, 15, 0, 0)

2、rrule

rrule(self, freq, dtstart=None, interval=1, wkst=None,count=None, until=None, bysetpos=None,bymonth=None, bymonthday=None, byyearday=None, byeaster=None,byweekno=None, byweekday=None, byhour=None, byminute=None, bysecond=None,cache=False)

  • freq:可以理解为单位。可以是 YEARLY, MONTHLY, WEEKLY,DAILY, HOURLY, MINUTELY, SECONDLY。即年月日周时分秒
  • dtstart,until:是开始和结束时间
  • wkst:周开始时间
  • interval:间隔
  • count:指定生成多少个
  • byxxx:指定匹配的周期。比如byweekday=(MO,TU)则只有周一周二的匹配。byweekday可以指定MO,TU,WE,TH,FR,SA,SU。即周一到周日。
>>> from dateutil import rrule

生成一个连续的日期列表
>>> list(rrule.rrule(rrule.DAILY,dtstart=parse('2018-11-1'),until=parse('2018-11-5')))
[datetime.datetime(2018, 11, 1, 0, 0), 
datetime.datetime(2018, 11, 2, 0, 0), 
datetime.datetime(2018, 11, 3, 0, 0), 
datetime.datetime(2018, 11, 4, 0, 0), 
datetime.datetime(2018, 11, 5, 0, 0)]

间隔一天
>>> list(rrule.rrule(rrule.DAILY,interval=2,dtstart=parse('2018-11-1'),until=parse('2018-11-5')))
[datetime.datetime(2018, 11, 1, 0, 0), 
datetime.datetime(2018, 11, 3, 0, 0), 
datetime.datetime(2018, 11, 5, 0, 0)]

只保留前3个元素
>>> list(rrule.rrule(rrule.DAILY,count=3,dtstart=parse('2018-11-1'),until=parse('2018-11-5')))
[datetime.datetime(2018, 11, 1, 0, 0), 
datetime.datetime(2018, 11, 2, 0, 0), 
datetime.datetime(2018, 11, 3, 0, 0)]

只要周一的
>>> list(rrule.rrule(rrule.DAILY,byweekday=rrule.MO,dtstart=parse('2018-11-1'),until=parse('2018-11-5')))
[datetime.datetime(2018, 11, 5, 0, 0)]

只要周六和周日的
>>> list(rrule.rrule(rrule.DAILY,byweekday=(rrule.SA,rrule.SU),dtstart=parse('2018-11-1'),until=parse('2018-11-5')))
[datetime.datetime(2018, 11, 3, 0, 0), 
datetime.datetime(2018, 11, 4, 0, 0)]

以月为间隔
>>> list(rrule.rrule(rrule.MONTHLY,dtstart=parse('2018-3-15'),until=parse('2018-7-30')))
[datetime.datetime(2018, 3, 15, 0, 0), 
datetime.datetime(2018, 4, 15, 0, 0), 
datetime.datetime(2018, 5, 15, 0, 0), 
datetime.datetime(2018, 6, 15, 0, 0), 
datetime.datetime(2018, 7, 15, 0, 0)]

计算时间差

rrule可计算出两个datetime对象间相差的年月日等时间数量

两个日期相差10天
>>> rrule.rrule(rrule.DAILY,dtstart=parse('2018-11-1'),until=parse('2018-11-10')).count()
10

某个日期到今天相差多少天
>>> rrule.rrule(rrule.DAILY,dtstart=parse('2018-11-1'),until=datetime.date.today()).count()
10

两个日期相差几个月
前一个月为m月,后一个月为n月,当日期不满整月时,差的月数按n-m算,当日期满整月后,差的月数按n-m+1算。
差的年数同月数的情况一样。
例子如下:

>>> rrule.rrule(rrule.MONTHLY,dtstart=parse('2018-3-15'),until=parse('2018-11-10')).count()
8
>>> rrule.rrule(rrule.MONTHLY,dtstart=parse('2018-3-15'),until=parse('2018-11-20')).count()
9

>>> rrule.rrule(rrule.YEARLY,dtstart=parse('2016-3-15'),until=parse('2018-2-10')).count()
2
>>> rrule.rrule(rrule.YEARLY,dtstart=parse('2016-3-15'),until=parse('2018-3-15')).count()
3
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,117评论 4 360
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,963评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 107,897评论 0 240
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,805评论 0 203
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,208评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,535评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,797评论 2 311
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,493评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,215评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,477评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,988评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,325评论 2 252
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,971评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,055评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,807评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,544评论 2 271
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,455评论 2 266

推荐阅读更多精彩内容