社区所有版块导航
Python
python开源   Django   Python   DjangoApp   pycharm  
DATA
docker   Elasticsearch  
aigc
aigc   chatgpt  
WEB开发
linux   MongoDB   Redis   DATABASE   NGINX   其他Web框架   web工具   zookeeper   tornado   NoSql   Bootstrap   js   peewee   Git   bottle   IE   MQ   Jquery  
机器学习
机器学习算法  
Python88.com
反馈   公告   社区推广  
产品
短视频  
印度
印度  
Py学习  »  Python

如何将numpy datetime64[ns]转换为python datetime?

Boris Salimov • 4 年前 • 1449 次点击  

我需要在单独的函数中转换熊猫帧值中的日期:

 def myfunc(lat, lon, when):
        ts = (when - np.datetime64('1970-01-01T00:00:00Z','s')) / np.timedelta64(1, 's')
        date = datetime.datetime.utcfromtimestamp(ts)
        print("Numpy date= ", when, " Python date= ", date)
        return float(90) - next_func(lat, lon, date)

调用此函数:

new_df['new_column'] =  np.vectorize(my_func)(lat, lon, new_df['datetime(LT)'])  

但它会引起错误:

ufunc subtract cannot use operands with types dtype('int64') and dtype('<M8[s]')

如何将numpy datetime64[ns]转换为python datetime?

Python社区是高质量的Python/Django开发社区
本文地址:http://www.python88.com/topic/38395
 
1449 次点击  
文章 [ 2 ]  |  最新文章 4 年前
hpaulj
Reply   •   1 楼
hpaulj    5 年前

我想知道你是否需要所有这些转换工作。使用正确的时间单位A datetime64 可以生成 datetime 直接对象。

我不确定你的 when 变量,但假设它来自 pandas 就像一个 DatetimeIndex :

In [56]: time = pandas.date_range('6/28/2013', periods=5, freq='5D')
In [57]: time
Out[57]: 
DatetimeIndex(['2013-06-28', '2013-07-03', '2013-07-08', '2013-07-13',
               '2013-07-18'],
              dtype='datetime64[ns]', freq='5D')

等效numpy数组

In [58]: time.values
Out[58]: 
array(['2013-06-28T00:00:00.000000000', '2013-07-03T00:00:00.000000000',
       '2013-07-08T00:00:00.000000000', '2013-07-13T00:00:00.000000000',
       '2013-07-18T00:00:00.000000000'], dtype='datetime64[ns]')
In [59]: time.values.tolist()
Out[59]: 
[1372377600000000000,
 1372809600000000000,
 1373241600000000000,
 1373673600000000000,
 1374105600000000000]

[ns] 结果是一个大整数,某种类型的“时间戳”。但如果我将时间单位转换为秒,甚至是微秒(us):

In [60]: time.values.astype('datetime64[s]')
Out[60]: 
array(['2013-06-28T00:00:00', '2013-07-03T00:00:00',
       '2013-07-08T00:00:00', '2013-07-13T00:00:00',
       '2013-07-18T00:00:00'], dtype='datetime64[s]')
In [61]: time.values.astype('datetime64[s]').tolist()
Out[61]: 
[datetime.datetime(2013, 6, 28, 0, 0),
 datetime.datetime(2013, 7, 3, 0, 0),
 datetime.datetime(2013, 7, 8, 0, 0),
 datetime.datetime(2013, 7, 13, 0, 0),
 datetime.datetime(2013, 7, 18, 0, 0)]

结果是 日期时间 物体。

Nikhil Unni
Reply   •   2 楼
Nikhil Unni    5 年前
def myfunc(lat, lon, when):
    ts = (when - np.datetime64('1970-01-01T00:00:00Z','s')) / np.timedelta64(1, 's')
    date = datetime.utcfromtimestamp(ts)
    print("Numpy date= ", when, " Python date= ", date)
    return float(90) - next_func(lat, lon, date)

尝试此代码

要将numpy datetime64[ns]转换为python datetime,只需尝试以下代码段

from datetime import datetime
datetime.utcfromtimestamp('your_time_stamp')