Python date string ไปยังวัตถุ Date


345

ฉันจะแปลงสตริงเป็นวัตถุวันที่ในไพ ธ อนได้อย่างไร

สตริงจะเป็น: "24052010"(ตรงกับรูปแบบ: "%d%m%Y")

ฉันไม่ต้องการวัตถุ datetime.datetime แต่ต้องการ datetime.date

คำตอบ:


586

คุณสามารถใช้strptimeในdatetimeแพ็คเกจของ Python:

>>> import datetime
>>> datetime.datetime.strptime('24052010', "%d%m%Y").date()
datetime.date(2010, 5, 24)

ฉันกำลังลองกระบวนการที่คล้ายกันยกเว้นสตริงป้อนข้อมูลของฉันไม่มีปีดังนั้นจึงดูเหมือนว่า '2405' 1900โดยค่าเริ่มต้นปีจะมาเป็น ปัญหานี้เกิดขึ้นเมื่อแยกวิเคราะห์วันที่เดือนกุมภาพันธ์เช่น '2902' ฉันได้รับข้อผิดพลาดValueError: day is out of range for monthนี้ ไม่แน่ใจว่าฉันจะตั้งปีเริ่มต้นในขณะที่แยกได้อย่างไร
Shubham Naik


59

คำถามที่เกี่ยวข้องโดยตรง:

ถ้าคุณมี

datetime.datetime.strptime("2015-02-24T13:00:00-08:00", "%Y-%B-%dT%H:%M:%S-%H:%M").date()

และคุณจะได้รับ:

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/local/lib/python2.7/_strptime.py", line 308, in _strptime
    format_regex = _TimeRE_cache.compile(format)
  File "/usr/local/lib/python2.7/_strptime.py", line 265, in compile
    return re_compile(self.pattern(format), IGNORECASE)
  File "/usr/local/lib/python2.7/re.py", line 194, in compile
    return _compile(pattern, flags)
  File "/usr/local/lib/python2.7/re.py", line 251, in _compile
    raise error, v # invalid expression
sre_constants.error: redefinition of group name 'H' as group 7; was group 4

และคุณลอง:

<-24T13:00:00-08:00", "%Y-%B-%dT%HH:%MM:%SS-%HH:%MM").date()

แต่คุณยังคงได้รับการสืบค้นกลับด้านบน

ตอบ:

>>> from dateutil.parser import parse
>>> from datetime import datetime
>>> parse("2015-02-24T13:00:00-08:00")
datetime.datetime(2015, 2, 24, 13, 0, tzinfo=tzoffset(None, -28800))

1
2015-07-20 09: 46: 55 + 00: 00 ฉันมีข้อมูลประเภทนี้ฉันจะได้รับวัตถุวันที่ได้อย่างไร
Hardik Gajjar

ใช้โมดูล re (นิพจน์ทั่วไป) เพื่อเปลี่ยนข้อมูลของคุณจาก "2015-07-20 09: 46: 55 + 00: 00" เป็น "2015-07-20T09: 46: 55-00: 00" จากนั้นใช้ dateutil.parse เพื่อรับวัตถุวันที่
Schopenhauer

1
ขอบคุณจริงปัญหาเป็นประเภท Dict วัตถุและฉันเพิ่งได้รับการแก้ปัญหาโดยใช้ dict.get ใช้
Hardik Gajjar

2
แนวคิดอื่นคือการอ่านคู่มือdocs.python.org/3/library/…ด้วยตนเองและสังเกตว่า% B ย่อมาจาก "ชื่อเต็มของเดือนเป็นชื่อสถานที่" ซึ่งเหมือนกับ "มกราคม" หรือ "ธันวาคม" ดังนั้น "02" จะไม่แยกวิเคราะห์
พลิก

1
สตริงรูปแบบวันที่ในสิ่งนี้ไม่ถูกต้องมันควรจะเป็น% m ไม่ใช่% B
ประกาศ

24

หากคุณขี้เกียจและไม่ต้องการต่อสู้กับตัวอักษรสตริงคุณสามารถไปกับparserโมดูล

from dateutil import parser
dt = parser.parse("Jun 1 2005  1:33PM")
print(dt.year, dt.month, dt.day,dt.hour, dt.minute, dt.second)
>2005 6 1 13 33 0

เพียงแค่ข้อความด้านข้างเนื่องจากเราพยายามจับคู่การanyแสดงสตริงมันช้ากว่า 10xstrptime


แก้ปัญหาได้ง่ายมากขอบคุณ ฉันพยายามแปลงวันที่ยาวนานของ Excel ที่แสดงเป็นMonday, June 03, 2019
Jeff Bluemel

5

คุณมีสตริงวันที่เช่นนี้ "24052010" และคุณต้องการวัตถุวันที่สำหรับสิ่งนี้

from datetime import datetime
cus_date = datetime.strptime("24052010", "%d%m%Y").date()

cus_date นี้จะให้วัตถุวันที่

คุณสามารถดึงข้อมูลสตริงวันที่จากวัตถุวันที่ของคุณโดยใช้สิ่งนี้

cus_date.strftime("%d%m%Y")

3

มีอีกห้องสมุดหนึ่งที่เรียกว่าarrowยอดเยี่ยมมากในการจัดการในวันไพ ธ อน

import arrow
import datetime

a = arrow.get('24052010', 'DMYYYY').date()
print(isinstance(a, datetime.date)) # True

1

ใช้โมดูลเวลาในการแปลงข้อมูล

ข้อมูลโค้ด:

import time 
tring='20150103040500'
var = int(time.mktime(time.strptime(tring, '%Y%m%d%H%M%S')))
print var
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.