Como dice Wes, read_sql de io / sql lo hará, una vez que haya obtenido una conexión a la base de datos utilizando una biblioteca compatible con DBI. Podemos ver dos ejemplos cortos usando las bibliotecas MySQLdb
y cx_Oracle
para conectarse a Oracle y MySQL y consultar sus diccionarios de datos. Aquí está el ejemplo de cx_Oracle
:
import pandas as pd
import cx_Oracle
ora_conn = cx_Oracle.connect('your_connection_string')
df_ora = pd.read_sql('select * from user_objects', con=ora_conn)
print 'loaded dataframe from Oracle. # Records: ', len(df_ora)
ora_conn.close()
Y aquí está el ejemplo equivalente para MySQLdb
:
import MySQLdb
mysql_cn= MySQLdb.connect(host='myhost',
port=3306,user='myusername', passwd='mypassword',
db='information_schema')
df_mysql = pd.read_sql('select * from VIEWS;', con=mysql_cn)
print 'loaded dataframe from MySQL. records:', len(df_mysql)
mysql_cn.close()