我有一个包含多个日期时间组件的网址列表。
urls = [ www.google.com/2018-10-26/2018-10-26T11:07:10.000Z, www.google.com//2018-10-26/2018-10-26T11:09:18.000Z]
我要对其排序,然后像这样返回列表:
urls = [ www.google.com/2018-10-26/2018-10-26T11:09:18.000Z, www.google.com//2018-10-26/2018-10-26T11:07:10.000Z]
因为第一个元素具有2018-10-26T11:09:18.000Z,所以它大于2018-10-26T11:07:10.000Z。有没有办法在列表理解中做到这一点?我假设这是正确的路径:
for url in urls:
date = url.split('/')[2]
但不确定从那里做什么。
答案 0 :(得分:3)
您可以根据时间戳(即,斜杠后的最后一个元素)以相反的顺序(最近的第一个)通过以下方式对您的网址进行排序:
urls.sort(key=lambda url: url.split('/')[-1], reverse=True)
答案 1 :(得分:1)
您可以使用定义排序键的函数对列表进行排序。例如:
urls = ['www.google.com/2018-10-26/2018-10-26T11:07:10.000Z', 'www.google.com//2018-10-26/2018-10-26T11:09:18.000Z']
sorted_urls = sorted(urls, key=lambda x: x.split('/')[-1], reverse=True)
print(sorted_urls)
# OUTPUT
# ['www.google.com//2018-10-26/2018-10-26T11:09:18.000Z', 'www.google.com/2018-10-26/2018-10-26T11:07:10.000Z']