I'm writing a script that plots some data with dates on the x axis (in matplotlib). I need to create a numpy.linspace out of those dates in order  to create a spline afterwards. Is it possible to do that?
What I've tried:
import datetime import numpy as np  dates = [     datetime.datetime(2015, 7, 2, 0, 31, 41),     datetime.datetime(2015, 7, 2, 1, 35),     datetime.datetime(2015, 7, 2, 2, 37, 9),     datetime.datetime(2015, 7, 2, 3, 59, 16),     datetime.datetime(2015, 7, 2, 5, 2, 23) ]  x = np.linspace(min(dates), max(dates), 500)  It throws this error:
TypeError: unsupported operand type(s) for *: 'datetime.datetime' and 'float'  I've also tried converting datetime to np.datetime64, but that doesn't work as well:
dates = [np.datetime64(i) for i in dates] x = np.linspace(min(dates), max(dates), 500)  Error:
TypeError: ufunc multiply cannot use operands with types dtype('<M8[us]') and dtype('float64') 
                As pointed out by @Joooeey and @Ehtesh Choudhury, pandas now has date_range, which makes creating numpy.linspace-like time series much simpler.
t = pd.date_range(start='2022-03-10',                   end='2022-03-15',                   periods=5)  If it's important to have this time series as a numpy array, simply
>>> t.values  array(['2022-03-10T00:00:00.000000000', '2022-03-11T06:00:00.000000000',        '2022-03-12T12:00:00.000000000', '2022-03-13T18:00:00.000000000',        '2022-03-15T00:00:00.000000000'], dtype='datetime64[ns]')  Have you considered using pandas? Using an approach from this possible duplicate question, you can make use of np.linspace in the following way
import pandas as pd  start = pd.Timestamp('2015-07-01') end = pd.Timestamp('2015-08-01') t = np.linspace(start.value, end.value, 100) t = pd.to_datetime(t)  To obtain an np.array of the linear timeseries
In [3]: np.asarray(t) Out[3]:  array(['2015-06-30T17:00:00.000000000-0700',        '2015-07-01T00:30:54.545454592-0700',        '2015-07-01T08:01:49.090909184-0700',                ...        '2015-07-31T01:58:10.909090816-0700',        '2015-07-31T09:29:05.454545408-0700',        '2015-07-31T17:00:00.000000000-0700'], dtype='datetime64[ns]') 
                        If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With