ฉันต้องการค้นหาวันที่ "เมื่อวาน" ในรูปแบบนี้MMDDYY
ใน Python
ตัวอย่างเช่นวันที่วันนี้จะแสดงดังนี้ 111009
ฉันสามารถทำสิ่งนี้ได้อย่างง่ายดายในวันนี้ แต่ฉันมีปัญหาในการทำโดยอัตโนมัติสำหรับ "เมื่อวาน"
ฉันต้องการค้นหาวันที่ "เมื่อวาน" ในรูปแบบนี้MMDDYY
ใน Python
ตัวอย่างเช่นวันที่วันนี้จะแสดงดังนี้ 111009
ฉันสามารถทำสิ่งนี้ได้อย่างง่ายดายในวันนี้ แต่ฉันมีปัญหาในการทำโดยอัตโนมัติสำหรับ "เมื่อวาน"
คำตอบ:
>>> from datetime import date, timedelta
>>> yesterday = date.today() - timedelta(days=1)
>>> yesterday.strftime('%m%d%y')
'110909'
from datetime import datetime, timedelta
yesterday = datetime.now() - timedelta(days=1)
yesterday.strftime('%m%d%y')
สิ่งนี้ควรทำในสิ่งที่คุณต้องการ:
import datetime
yesterday = datetime.datetime.now() - datetime.timedelta(days = 1)
print yesterday.strftime("%m%d%y")
ทุกคำตอบที่ถูกต้อง แต่ฉันต้องการที่จะพูดถึงว่าเวลาเดลต้ายอมรับข้อโต้แย้งเชิงลบ
>>> from datetime import date, timedelta
>>> yesterday = date.today() + timedelta(days=-1)
>>> print(yesterday.strftime('%m%d%y')) #for python2 remove parentheses
ฉันขอเพิ่มความเป็นสากลและจัดรูปแบบวันที่ให้เป็นไปตามมาตรฐานสากลได้หรือไม่และไม่ได้อยู่ในเดือนแปลก ๆ ของปีนั่นเป็นเรื่องธรรมดาในสหรัฐฯ
from datetime import datetime, timedelta
yesterday = datetime.now() - timedelta(days=1)
yesterday.strftime('%Y-%m-%d')
เพื่อขยายคำตอบที่ได้รับจากคริส
ถ้าคุณต้องการเก็บวันที่ในตัวแปรในรูปแบบเฉพาะนี่เป็นวิธีที่สั้นและมีประสิทธิภาพที่สุดเท่าที่ฉันรู้
>>> from datetime import date, timedelta
>>> yesterday = (date.today() - timedelta(days=1)).strftime('%m%d%y')
>>> yesterday
'020817'
ถ้าคุณต้องการให้มันเป็นจำนวนเต็ม (ซึ่งจะมีประโยชน์)
>>> yesterday = int((date.today() - timedelta(days=1)).strftime('%m%d%y'))
>>> yesterday
20817
print((pd.to_datetime('Today') - pd.Timedelta('1 days')).strftime('%m%d%y'))