python对日期型数据排序_在python中对日期字符串进行排序,最好不使用日期对象...

这篇博客讨论了如何在Python中对日期字符串进行排序,提供了多种方法,包括使用pandas、numpy、datetime和自定义函数。示例代码展示了如何处理'Month DayNumber'格式的日期字符串,同时考虑了异常处理和列表中非日期项的排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

所以,我有一个字符串列表,这些字符串的格式都是Month DayNumber,比如

['March 1', 'March 9', 'April 14', 'March 12']

我需要对列表进行排序,以便所有日期都按日历中的顺序排列。有什么小窍门吗?是否有内置方法可以帮助我,或者我应该使用lambda设计自定义排序?

除了key论点?

您可以使用熊猫模块。用PIP安装。

你可以这样做:

import pandas as pd

dates = ['March 1', 'March 9', 'April 14', 'March 12']

df = pd.DataFrame(dates)

df = pd.to_datetime(df[0], format="%B %d")

df=df.sort_values()

print (df)

此日期时间格式非常有用,例如,如果您希望列表元素的日期或月份只执行以下操作:

df.month

df.day

一种方法是使用numpy.argsort与datetime库结合使用。

import numpy as np

from datetime import datetime

lst = ['March 1', 'March 9', 'April 14', 'March 12']

arr = np.array(lst)

res = arr[np.argsort([datetime.strptime(i+' 2018', '%B %d %Y') for i in lst])].tolist()

结果:

['March 1', 'March 9', 'March 12', 'April 14']

这是可能的,因为在内部,日期只是数字数据。在这种情况下,我们附上一个任意的2018年来创建datetime对象。

您还可以利用日历模块:

from calendar import month_name

months = list(month_name)

def parser (text):

"""Parses 'englishmonthname_whitespace_day-number' into string 'monthNR.dayNr'.

Will pad a zero to allow for string based sorting."""

try:

month,day = text.split()

monthAsIdx = months.index(month.strip())

return '{:02d}.{:02d}'.format(monthAsIdx,int(day)) # return index in list.days

except (ValueError, IndexError): # ValueError if not enough elements in string,

# IndexError if not in list of month names

return"99.99" # put last - all errors are put last w/o specific reordering

dates = ['TooFew', 'EnoughBut NotInList', 'March 1', 'March 9', 'April 14', 'March 12']

for n in dates:

print(parser(n))

sortedDates = sorted(dates, key=lambda x: parser(x))

print(sortedDates)

输出:

# result of parser()

99.99

99.99

03.01

03.09

04.14

03.12

# sorted by key/lambda

['March 1', 'March 9', 'March 12', 'April 14', 'TooFew', 'EnoughBut NotInList']

您可能想回顾一下这个问题:将字符串转换成日期时间

在分析之后,您可以根据从分析字符串到日期时间对象(可排序)中获得的值按日期排序。

我已经完成了这项工作,并对代码进行了排序(testing,key=lambda x:datetime.datetime.strptime(x,'%m-%y-%d')),但它不起作用,所以我回到了绘图板。

你确定%Y应该在那里吗?我只使用'%B %d'(其中%B是当前区域中的完整月份名称)。对我来说,这对你提供的数据很有吸引力。

当我发自内心地写这篇文章时,我的数据是不同的,我的错。问题是,数据将以列表而不是字符串的形式传递,并引发错误。我会调查的,谢谢你的帮助。

可能性:

使用字典并使用key/value。

使用字符串匹配(regex)

更多…

或者谷歌,使用以下任何一个:

将字符串转换为日期时间

在python上将字符串转换为日期类型

如何在python中将字符串日期转换为datetime格式?

要提供可能的解决方案:

Input_list = [{'month':'March', 'day':30}, {'month':'March', 'day':10}]

newlist = sorted(Input_list, key=lambda k: k['month'])

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值