แยกวิเคราะห์สตริงวันที่และเปลี่ยนรูปแบบ


116

ฉันมีสตริงวันที่ที่มีรูปแบบ 'Mon Feb 15 2010' ฉันต้องการเปลี่ยนรูปแบบเป็น '15 / 02/2010 ' ฉันจะทำเช่นนี้ได้อย่างไร?


ซ้ำทั้งหมดของเหล่านี้: stackoverflow.com/search?q=%5Bpython%5D+parse+date รายการนี้ซ้ำกันทุก
ประการ

คำตอบ:


154

datetime โมดูลสามารถช่วยคุณได้:

datetime.datetime.strptime(date_string, format1).strftime(format2)

สำหรับตัวอย่างเฉพาะที่คุณสามารถทำได้

>>> datetime.datetime.strptime('Mon Feb 15 2010', '%a %b %d %Y').strftime('%d/%m/%Y')
'15/02/2010'
>>>

2
datetime.datetime (จ. 15 ก.พ. 2553 "% a% b% d% Y"). strftime ("% d /% m /% Y") ถูกต้องหรือไม่ แต่ฉันได้รับข้อผิดพลาด
Nimmy

1
@nimmyliji: ได้รับการแก้ไข 10 นาทีก่อนที่คุณจะโพสต์ความคิดเห็นของคุณ และแน่นอนคุณควรมีdate_stringเป็นสตริง
SilentGhost

3
โปรดดูตัวอย่างการทำงานอย่างสมบูรณ์;) สิ่งที่จำเป็นต้องนำเข้า / ...
เข้ารหัส

format1ต้องเป็นสตริงเพื่อแสดงรูปแบบของสตริงวันที่อินพุต format2คือรูปแบบสตริงเป้าหมายที่จะส่งออก
ธ อร์ซัมมอนเนอร์

1
คุณสามารถอธิบายเพิ่มเติมได้ไหมว่า format1 จะมีหน้าตาอย่างไรในตัวอย่างนี้
user1767754

59

คุณสามารถติดตั้งdateutilไลบรารีใช้ฟังก์ชั่นสามารถคิดออกว่ารูปแบบสตริงอยู่ในโดยไม่ต้องระบุรูปแบบเหมือนที่คุณทำกับparsedatetime.strptime

from dateutil.parser import parse
dt = parse('Mon Feb 15 2010')
print(dt)
# datetime.datetime(2010, 2, 15, 0, 0)
print(dt.strftime('%d/%m/%Y'))
# 15/02/2010

dateutil.parse เป็นทางเลือกที่ดีกว่าหากไม่ทราบรูปแบบที่แน่นอนของสตริง ISO ที่ถูกต้องตามกฎหมาย ISO อาจมีหรือไม่มีไมโครวินาทีก็ได้ อาจมีหรือไม่มี "Z" ต่อท้าย datetime.strptime ไม่ยืดหยุ่นพอที่จะรองรับสิ่งนั้น
Michael Kariv

4
Pase Date ควรใช้ด้วยความระมัดระวัง parse ('12 .07.2017 ') ส่งคืนวันที่และเวลา (2017, 12, 7, .. ) แต่การแยกวิเคราะห์ ('13 .07.2017') ส่งกลับ. datetime (2017, 7, 13, ... )
ego2dot0

ในpython 3.xความต้องการในการติดตั้งpython-dateutil pip install python-dateutil
AB Abhi


23

แปลงสตริงเป็นวัตถุ datetime

from datetime import datetime
s = "2016-03-26T09:25:55.000Z"
f = "%Y-%m-%dT%H:%M:%S.%fZ"
out = datetime.strptime(s, f)
print(out)
output:
2016-03-26 09:25:55

นี่ไม่ได้เป็นไปตามรูปแบบที่เขาถามซึ่งมีสตริงเดือน "ก.พ. " อยู่ในนั้น
Shahir Ansari

@ShahirAnsari คุณสามารถเปลี่ยนรูปแบบได้ตามต้องการอ้างอิง " docs.python.org/3/library/datetime.html "
anjaneyulubatta505

14

เนื่องจากคำถามนี้มักจะเกิดขึ้นนี่คือคำอธิบายง่ายๆ

datetimeหรือtimeโมดูลมีหน้าที่สำคัญสองอย่าง

  • strftime - สร้างการแสดงวันที่หรือเวลาสตริงจากวัตถุวันที่เวลาหรือเวลา
  • strptime - สร้างวัตถุ datetime หรือ time จากสตริง

ในทั้งสองกรณีเราต้องการสตริงการจัดรูปแบบ เป็นตัวแทนที่บอกว่าวันที่หรือเวลาถูกจัดรูปแบบอย่างไรในสตริงของคุณ

ตอนนี้สมมติว่าเรามีวัตถุวันที่

>>> from datetime import datetime
>>> d = datetime(2010, 2, 15)
>>> d
datetime.datetime(2010, 2, 15, 0, 0)

หากเราต้องการสร้างสตริงจากวันที่นี้ในรูปแบบ 'Mon Feb 15 2010'

>>> s = d.strftime('%a %b %d %y')
>>> print s
Mon Feb 15 10

สมมติว่าเราต้องการแปลงสิ่งนี้sอีกครั้งเป็นdatetimeวัตถุ

>>> new_date = datetime.strptime(s, '%a %b %d %y')
>>> print new_date
2010-02-15 00:00:00

อ้างอิงเอกสารนี้คำสั่งการจัดรูปแบบทั้งหมดเกี่ยวกับวันที่และเวลา


ฉันชอบคำอธิบายของคุณ
enchance

2

เพียงเพื่อความสมบูรณ์: เมื่อแยกวิเคราะห์วันที่โดยใช้strptime()และวันที่มีชื่อของวันเดือน ฯลฯ โปรดทราบว่าคุณต้องคำนึงถึงสถานที่นั้น

มีการกล่าวถึงเป็นเชิงอรรถในเอกสารด้วย

ตัวอย่างเช่น:

import locale
print(locale.getlocale())

>> ('nl_BE', 'ISO8859-1')

from datetime import datetime
datetime.strptime('6-Mar-2016', '%d-%b-%Y').strftime('%Y-%m-%d')

>> ValueError: time data '6-Mar-2016' does not match format '%d-%b-%Y'

locale.setlocale(locale.LC_ALL, 'en_US')
datetime.strptime('6-Mar-2016', '%d-%b-%Y').strftime('%Y-%m-%d')

>> '2016-03-06'

2

@codeling และ @ user1767754: 2 บรรทัดต่อไปนี้จะใช้ได้ ฉันไม่เห็นใครโพสต์วิธีแก้ปัญหาที่สมบูรณ์สำหรับปัญหาตัวอย่างที่ถูกถาม หวังว่าจะเป็นคำอธิบายที่เพียงพอ

import datetime

x = datetime.datetime.strptime("Mon Feb 15 2010", "%a %b %d %Y").strftime("%d/%m/%Y")
print(x)

เอาท์พุต:

15/02/2010

1

คุณสามารถทำได้โดยใช้แพนด้าเช่นกัน:

import pandas as pd

pd.to_datetime('Mon Feb 15 2010', format='%a %b %d %Y').strftime('%d/%m/%Y')

เอาท์พุต:

'15/02/2010'

คุณสามารถใช้แนวทางแพนด้าสำหรับประเภทข้อมูลต่างๆได้ดังนี้

import pandas as pd
import numpy as np

def reformat_date(date_string, old_format, new_format):
    return pd.to_datetime(date_string, format=old_format, errors='ignore').strftime(new_format)

date_string = 'Mon Feb 15 2010'
date_list = ['Mon Feb 15 2010', 'Wed Feb 17 2010']
date_array = np.array(date_list)
date_series = pd.Series(date_list)

old_format = '%a %b %d %Y'
new_format = '%d/%m/%Y'

print(reformat_date(date_string, old_format, new_format))
print(reformat_date(date_list, old_format, new_format).values)
print(reformat_date(date_array, old_format, new_format).values)
print(date_series.apply(lambda x: reformat_date(x, old_format, new_format)).values)

เอาท์พุต:

15/02/2010
['15/02/2010' '17/02/2010']
['15/02/2010' '17/02/2010']
['15/02/2010' '17/02/2010']

0

ใช้ไลบรารีวันที่และเวลา http://docs.python.org/library/datetime.htmlค้นหา 9.1.7 especiall strptime () strftime () Behavior¶ตัวอย่าง http://pleac.sourceforge.net/pleac_python/datesandtimes.html


สำหรับข้อผิดพลาดข้างต้น nimmyliji คุณควรทำ datetime.datetime.strptime ("จันทร์ 15 กุมภาพันธ์ 2010", "% a% b% d% Y") strftime ("% d /% m /% Y") ให้ ' 15/02/2010 '
Roman A.Taycher
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.