pandas
SQL ServerからDataframeへの読み込み
サーチ…
pyodbcの使用
import pandas.io.sql
import pyodbc
import pandas as pd
パラメータを指定する
# Parameters
server = 'server_name'
db = 'database_name'
UID = 'user_id'
接続を作成する
# Create the connection
conn = pyodbc.connect('DRIVER={SQL Server};SERVER=' + server + ';DATABASE=' + db + '; UID = ' + UID + '; PWD = ' + UID + 'Trusted_Connection=yes')
パンダのデータフレームへの問い合わせ
# Query into dataframe
df= pandas.io.sql.read_sql('sql_query_string', conn)
接続ループでpyodbcを使用する
import os, time
import pyodbc
import pandas.io.sql as pdsql
def todf(dsn='yourdsn', uid=None, pwd=None, query=None, params=None):
''' if `query` is not an actual query but rather a path to a text file
containing a query, read it in instead '''
if query.endswith('.sql') and os.path.exists(query):
with open(query,'r') as fin:
query = fin.read()
connstr = "DSN={};UID={};PWD={}".format(dsn,uid,pwd)
connected = False
while not connected:
try:
with pyodbc.connect(connstr,autocommit=True) as con:
cur = con.cursor()
if params is not None: df = pdsql.read_sql(query, con,
params=params)
else: df = pdsql.read_sql(query, con)
cur.close()
break
except pyodbc.OperationalError:
time.sleep(60) # one minute could be changed
return df
Modified text is an extract of the original Stack Overflow Documentation
ライセンスを受けた CC BY-SA 3.0
所属していない Stack Overflow