58

pyodbc を使用して SQL サーバーからデータを取得し、Python を使用してテーブルに出力しようとしています。ただし、列の各行の実際のデータ値ではなく、列名とデータ型などしか取得できないようです。

基本的に、サーバー データを取得してテーブルに表示する Excel シートを複製しようとしています。サーバーへの接続に問題はありませんが、テーブルに入る実際のデータが見つからないようです。

これが私のコードの例です:

import pyodbc
cnxn = pyodbc.connect('DRIVER={SQL Server};SERVER=SQLSRV01;DATABASE=DATABASE;UID=USER;PWD=PASSWORD')
cursor = cnxn.cursor()

cursor.execute("SELECT * FROM sys.tables")
tables = cursor.fetchall()
#cursor.execute("SELECT WORK_ORDER.TYPE,WORK_ORDER.STATUS, WORK_ORDER.BASE_ID, WORK_ORDER.LOT_ID FROM WORK_ORDER")

for row in cursor.columns(table='WORK_ORDER'):
    print row.column_name
    for field in row:
        print field

ただし、この結果は、テーブル名、列名、およびいくつかの整数、「なし」など、私にとって興味のないものだけを提供します。

STATUS_EFF_DATE
DATABASE
dbo
WORK_ORDER
STATUS_EFF_DATE
93
datetime
23
16
3
None
0
None
None
9
3
None
80
NO
61

そのため、テーブルを埋めるための値をどこで取得できるかはよくわかりません。table='WORK_ORDER' にあるはずですが、別のテーブル名の下にある可能性はありますか? 欠落しているデータを印刷する方法はありますか?

アドバイスや提案をいただければ幸いです。

4

8 に答える 8

86

あなたはとても近いです!

import pyodbc
cnxn = pyodbc.connect('DRIVER={SQL Server};SERVER=SQLSRV01;DATABASE=DATABASE;UID=USER;PWD=PASSWORD')
cursor = cnxn.cursor()

cursor.execute("SELECT WORK_ORDER.TYPE,WORK_ORDER.STATUS, WORK_ORDER.BASE_ID, WORK_ORDER.LOT_ID FROM WORK_ORDER")
for row in cursor.fetchall():
    print row

(「columns()」関数は、実際のデータではなく、名前付きテーブルの列に関するメタデータを収集します)。

于 2012-07-12T12:28:23.300 に答える
14

テーブルに格納されている実際のデータを受信するには、fetch ...()関数のいずれかを使用するか、カーソルをイテレータとして使用する必要があります(つまり、「カーソル内の行」...)。これはドキュメントで説明されています:

cursor.execute("select user_id, user_name from users where user_id < 100")
rows = cursor.fetchall()
for row in rows:
    print row.user_id, row.user_name
于 2012-07-12T12:00:34.603 に答える
13

Pandas を使用して情報を取得し、データフレームとして取得することができます

import pyodbc as cnn
import pandas as pd

cnxn = pyodbc.connect('DRIVER={SQL Server};SERVER=SQLSRV01;DATABASE=DATABASE;UID=USER;PWD=PASSWORD')

# Copy to Clipboard for paste in Excel sheet
def copia (argumento):
    df=pd.DataFrame(argumento)
    df.to_clipboard(index=False,header=True)


tableResult = pd.read_sql("SELECT * FROM YOURTABLE", cnxn) 

# Copy to Clipboard
copia(tableResult)

# Or create a Excel file with the results
df=pd.DataFrame(tableResult)
df.to_excel("FileExample.xlsx",sheet_name='Results')

これが役立つことを願っています!乾杯!

于 2019-04-04T20:22:52.523 に答える