ฉันมีdatetime
วัตถุPython ที่ฉันต้องการแปลงเป็นเวลา unix หรือวินาที / มิลลิวินาทีนับตั้งแต่ยุค 1970
ฉันจะทำสิ่งนี้ได้อย่างไร
$ python -c 'import time; print(time.time())'
ซึ่งให้:1584487455.698623
ฉันมีdatetime
วัตถุPython ที่ฉันต้องการแปลงเป็นเวลา unix หรือวินาที / มิลลิวินาทีนับตั้งแต่ยุค 1970
ฉันจะทำสิ่งนี้ได้อย่างไร
$ python -c 'import time; print(time.time())'
ซึ่งให้:1584487455.698623
คำตอบ:
ฉันคิดว่าวิธีที่ง่ายที่สุดคือ
import datetime
epoch = datetime.datetime.utcfromtimestamp(0)
def unix_time_millis(dt):
return (dt - epoch).total_seconds() * 1000.0
%s
ขึ้นอยู่กับระบบปฏิบัติการ! ดังนั้นทุกคนต้องการรหัสทำงานเชื่อถือได้โดยไม่คำนึงถึงในที่ OS %s
ที่ใช้ไม่ควร สำหรับ 2.3 <py ver <2.7 เราสามารถสร้างสิ่งtotal_seconds()
นี้ได้ง่ายๆ:delta.days*86400+delta.seconds+delta.microseconds/1e6
dt
ต้องอยู่ใน UTC (ไม่ใช่ในพื้นที่) ดูคำตอบที่คล้ายกันกับ Python 2.6 / 3 รองรับ
utcfromtimestamp(0)
อาจทำให้ 'tz' ออฟเซ็ตเฉพาะในกรณีที่ 'tz' ไม่ใช่ 0 นี่เป็นเพราะdt
ในdt- epoch
มี 'tz' คำนวณในที่ที่เป็นยุคเวลา UTC วิธีที่ดีที่สุดในการคำนวณยุคคือการepoch = datetime.datetime(1970, 1, 1)
พิจารณาของเขตเวลา
datetime.utcfromtimestamp(0)
คืนค่าเวลาโดยไม่มี tzinfo มันมีสิทธิในชื่อวิธีการUTC fromtimestamp datetime.utcfromtimestamp(0).replace(tzinfo=pytz.UTC)
เพื่อที่จะทำให้มันไม่ใช่ไร้เดียงสาที่ฉันต้องทำสิ่งที่ชอบ นี่เป็นสิ่งจำเป็นหากdt
เขตเวลาทราบหรือไม่เช่นนั้นคุณจะได้รับTypeError: can't subtract offset-naive and offset-aware datetimes
ใน Python 3.3 เพิ่มวิธีการใหม่timestamp
:
import datetime
seconds_since_epoch = datetime.datetime.now().timestamp()
คำถามของคุณระบุว่าคุณต้องการมิลลิวินาทีซึ่งคุณจะได้รับเช่นนี้:
milliseconds_since_epoch = datetime.datetime.now().timestamp() * 1000
ถ้าคุณใช้timestamp
กับวัตถุ datetime ไร้เดียงสามันจะสันนิษฐานว่ามันอยู่ในเขตเวลาท้องถิ่น ใช้ออบเจ็กต์ datetime ที่รับรู้เขตเวลาหากนี่ไม่ใช่สิ่งที่คุณตั้งใจจะเกิดขึ้น
.timestamp()
เมธอดสันนิษฐานว่า datetime ที่ไร้เดียงสาอยู่ในเขตเวลาท้องถิ่น (และเวลาท้องถิ่นอาจไม่ชัดเจน) ถ้ามันอยู่ใน UTC แล้วใช้แทนdt.replace(tzinfo=timezone.utc).timestamp()
datetime.datetime.timestamp(datetime.datetime.now())
datetime.datetime.now(pytz.timezone('Europe/Paris')).timestamp() == datetime.datetime.now(pytz.utc).timestamp() == datetime.datetime.utcnow().timestamp()
แต่ไม่เท่ากับ (เสมอ) เท่ากับdatetime.datetime.now().timestamp()
(อันสุดท้ายนี้เท่ากับส่วนที่เหลือถ้า local tz คือ UTC ... )
fromtimestamp
( docs.python.org/3/library/… )
>>> import datetime
>>> # replace datetime.datetime.now() with your datetime object
>>> int(datetime.datetime.now().strftime("%s")) * 1000
1312908481000
หรือความช่วยเหลือของโมดูลเวลา (และไม่มีการจัดรูปแบบวันที่):
>>> import datetime, time
>>> # replace datetime.datetime.now() with your datetime object
>>> time.mktime(datetime.datetime.now().timetuple()) * 1000
1312908681000.0
ตอบด้วยความช่วยเหลือจาก: http://pleac.sourceforge.net/pleac_python/datesandtimes.html
เอกสารอ้างอิง:
.timetuple()
ส่งคืนtm_isdst=-1
มันบังคับmktime()
ให้คาดเดา อาจเดาผิดระหว่าง DST (โอกาส 50% ของข้อผิดพลาด +/- ชั่วโมง) ทั้ง '% s' และmktime()
อาจใช้อ็อฟเซ็ต utc ผิดสำหรับวันที่ผ่านมา คุณต้องการเขตเวลาในอดีต db เช่นจัดเตรียมโดยpytz
โมดูลเพื่อแปลงเวลาท้องถิ่นได้อย่างน่าเชื่อถือเป็นเวลาประทับ POSIX (เว้นแต่ว่า OS ได้จัดเตรียมฐานข้อมูลไว้แล้ว)
time.mktime(ts.timetuple())
โดยที่ ts เป็นวัตถุ datetime ของไพ
mktime/timetuple
อ่านความคิดเห็นของฉันข้างต้นเกี่ยวกับ นอกจากนี้ยังตัดtimetuple()
เศษส่วนของหนึ่งวินาทีและจุดของคำถามคือการได้รับการประทับเวลาด้วยความแม่นยำมิลลิวินาที
คุณสามารถใช้ Delorean เพื่อเดินทางในอวกาศและเวลา!
import datetime
import delorean
dt = datetime.datetime.utcnow()
delorean.Delorean(dt, timezone="UTC").epoch
นี่คือวิธีที่ฉันทำ:
from datetime import datetime
from time import mktime
dt = datetime.now()
sec_since_epoch = mktime(dt.timetuple()) + dt.microsecond/1000000.0
millis_since_epoch = sec_since_epoch * 1000
คำแนะนำจากเอกสาร Python 2.7 สำหรับtime
โมดูล
time
โมดูล แต่ OP ถามเกี่ยวกับdatetime
โมดูล FWIW ยุคปัจจุบันที่ง่ายที่สุดคือint(time.time())
from datetime import datetime
from calendar import timegm
# Note: if you pass in a naive dttm object it's assumed to already be in UTC
def unix_time(dttm=None):
if dttm is None:
dttm = datetime.utcnow()
return timegm(dttm.utctimetuple())
print "Unix time now: %d" % unix_time()
print "Unix timestamp from an existing dttm: %d" % unix_time(datetime(2014, 12, 30, 12, 0))
timegm()
ใช้ได้กับเวลา utc เท่านั้น มันไม่ได้ใช้tm_isdst
ดังนั้นคุณสามารถใช้แทนutcnow.timetuple()
utcnow.utctimetuple()
หมายเหตุ: การใช้naive_local_datetime.utctimetuple()
จะผิดที่นี่ มันไม่ได้แปลเวลาท้องถิ่นเป็น utc นอกจากนี้timetuple()
เรียกแถบเศษส่วนของวินาทีจากผลลัพธ์ (ไม่ว่ามันจะขึ้นอยู่กับแอพพลิเคชั่น) คำถามถามเกี่ยวกับ * milli * วินาทีไม่ใช่วินาที
utctimetuple()
แถบเศษส่วนของวินาที การคูณด้วย1000
จะไม่ทำให้พวกมันกลับมา
>>> import datetime
>>> import time
>>> import calendar
>>> #your datetime object
>>> now = datetime.datetime.now()
>>> now
datetime.datetime(2013, 3, 19, 13, 0, 9, 351812)
>>> #use datetime module's timetuple method to get a `time.struct_time` object.[1]
>>> tt = datetime.datetime.timetuple(now)
>>> tt
time.struct_time(tm_year=2013, tm_mon=3, tm_mday=19, tm_hour=13, tm_min=0, tm_sec=9, tm_wday=1, tm_yday=78, tm_isdst=-1)
>>> #If your datetime object is in utc you do this way. [2](see the first table on docs)
>>> sec_epoch_utc = calendar.timegm(tt) * 1000
>>> sec_epoch_utc
1363698009
>>> #If your datetime object is in local timeformat you do this way
>>> sec_epoch_loc = time.mktime(tt) * 1000
>>> sec_epoch_loc
1363678209.0
[1] http://docs.python.org/2/library/datetime.html#datetime.date.timetuple
นี่เป็นอีกรูปแบบหนึ่งของการแก้ปัญหาด้วยการทำให้วัตถุเวลาของคุณเป็นปกติ
def to_unix_time(timestamp):
epoch = datetime.datetime.utcfromtimestamp(0) # start of epoch time
my_time = datetime.datetime.strptime(timestamp, "%Y/%m/%d %H:%M:%S.%f") # plugin your time object
delta = my_time - epoch
return delta.total_seconds() * 1000.0
รหัสแพนด้าเล็กน้อย:
import pandas
def to_millis(dt):
return int(pandas.to_datetime(dt).value / 1000000)
import time
seconds_since_epoch = time.mktime(your_datetime.timetuple()) * 1000
* 1000
seconds_since_epoch
การถอนคำตอบนี้เนื่องจากฉันไม่สนใจมิลลิวินาทีในขณะนี้
นี่คือฟังก์ชั่นที่ฉันทำตามคำตอบข้างต้น
def getDateToEpoch(myDateTime):
res = (datetime.datetime(myDateTime.year,myDateTime.month,myDateTime.day,myDateTime.hour,myDateTime.minute,myDateTime.second) - datetime.datetime(1970,1,1)).total_seconds()
return res
คุณสามารถตัดค่าที่ส่งคืนเช่นนี้: str (int (res)) หากต้องการส่งคืนโดยไม่มีค่าทศนิยมที่จะใช้เป็นสตริงหรือเพียงแค่ int (ไม่มี str)
โซลูชันอื่นสำหรับการแปลงข้อมูลวันที่เป็น unixtimestampmillis
private static readonly DateTime UnixEpoch = new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc);
public static long GetCurrentUnixTimestampMillis()
{
DateTime localDateTime, univDateTime;
localDateTime = DateTime.Now;
univDateTime = localDateTime.ToUniversalTime();
return (long)(univDateTime - UnixEpoch).TotalMilliseconds;
}