我使用的是sqlalchemy
,它允許對最近發佈的0.14.1版本的熊貓進行SQL查詢。python pandas parse_dates在pandas 0.14.1中sqlalchemy的列通配符?
import pandas as pd
from dateutil import parser
from sqlalchemy import create_engine
import datetime
a=[['Datetime', 'Now Date', 'numbers', 'mixed'], ['1/2/2014', datetime.datetime.now(),6, 'z1'], ['1/3/2014', datetime.datetime.now(), 3, 'z1']]
df = pd.DataFrame(a[1:],columns=a[0])
df['Datetime']=df['Datetime'].map(lambda x: parser.parse(x))
engine=create_engine('sqlite:///:memory:')
df.to_sql('db_table',engine, index=False)
df_new=pd.read_sql_query("SELECT * FROM db_table ",engine)
>>> df.dtypes
Datetime datetime64[ns]
Now Date datetime64[ns]
numbers int64
mixed object
dtype: object
>>> df_new.dtypes
Datetime object
Now Date object
numbers int64
mixed object
dtype: object
正如你所看到的,餵養它進入發動機的時候我原來datetime
格式丟失。但是,熊貓給你一種解析方法。
df_new=pd.read_sql_query("SELECT * FROM db_table ",engine, parse_dates=['Datetime','Now Date'])
>>> df_new.dtypes
Datetime datetime64[ns]
Now Date datetime64[ns]
numbers int64
mixed object
dtype: object
問題的是我飼養不同種類的datetimes
與不同的列名的引擎,我不能手動指定每個列名。我有太多的東西需要解析,而且它在不斷變化。我正在尋找一個解決方案,就像這樣:
df_new=pd.read_sql_query("SELECT * FROM db_table ",engine, parse_dates=['*Date*'])