将pyodbc查询结果读入变量

问题描述 投票:0回答:1

Context:我试图通过Pyodbc从SQL Server查询数据,并使用循环逻辑将结果读入下面查询块中的变量。

问题:有人可以帮我修改下面的代码块,以便它通过循环逻辑正确填充变量吗?我怀疑是因为我在查询游标上使用fetchall()方法,每个结果行都转换为列表中的元组-这似乎使它下面的循环逻辑无效。有人可以建议替代解决方案吗?

from constantcontact import ConstantContact
from constantcontact import Contact
import requests
import json
import pyodbc

username = 'REDACTED'
password = 'REDACTED'

sample_contact_connection = pyodbc.connect("Driver={ODBC Driver 13 for SQL Server};""Server=PC;""Database=leadgen_sandbox;""Username="+username+";""Password="+password+";""Trusted_Connection=yes;")
sample_contact_cursor = sample_contact_connection.cursor()

sample_contact_query = "SELECT first_name,last_name,title,company_name,email_address FROM leadgen_sandbox.dbo.sample_contacts"
sample_contact_connection.autocommit = True
sample_contact_cursor.execute(sample_contact_query)
print(sample_contact_cursor.fetchall())

constantcontact = ConstantContact('REDACTED','REDACTED')
list_id = '1816761971'

for [first_name, last_name, title, company_name, email_address] in sample_contact_cursor.fetchall():
  new_contact = Contact()
  new_contact.set_first_name(''+first_name+'')
  new_contact.set_last_name(''+last_name+'')
  new_contact.set_job_title(''+title+'')
  new_contact.set_company_name(''+company_name+'')
  new_contact.add_list_id(''+list_id+'')
  new_contact.set_email_address(''+email_address+'')
  response = constantcontact.post_contacts(new_contact)
  response_text = json.dumps(response, indent = 4, sort_keys = True)
  print(response_text)
  sample_contact_connection.close()
python sql-server pyodbc
1个回答
0
投票

当您调用sample_contact_cursor.fetchall()时,您已经用尽了游标的内容。因此,其内容将不再可用于循环。 在循环之前删除打印将解决此问题。同样,.fetchall()在循环中是多余的,因为无论如何在for循环中将逐行读取每一行。您也可以这样写:

for [first_name, last_name, title, company_name, email_address] in sample_contact_cursor:
  new_contact = Contact()
  new_contact.set_first_name(''+first_name+'')
  new_contact.set_last_name(''+last_name+'')
  #Write your remaining code

如果确实需要先打印光标,然后运行循环,则必须在循环之前重新执行一次光标,如下所示:

sample_contact_cursor.execute(sample_contact_query)
print(sample_contact_cursor.fetchall())

constantcontact = ConstantContact('REDACTED','REDACTED')
list_id = '1816761971'

sample_contact_cursor.execute(sample_contact_query)

for [first_name, last_name, title, company_name, email_address] in sample_contact_cursor:
  new_contact = Contact()
  new_contact.set_first_name(''+first_name+'')
  new_contact.set_last_name(''+last_name+'')
  #Write your remaining code
© www.soinside.com 2019 - 2024. All rights reserved.