こんにちは私はPythonでデータベースに接続していくつかの情報を取得し、電子メールを送るスクリプトに取り組んでいます。私はPsycopgで行ったクエリに問題があります。Python Psycopg2 cursor.execute returnedなし
created_at = nb_days
のすべてのユーザーを取得したいと思います。私のクエリのNavicat/pgAdminでとI'haveで非常に良い仕事クエリで53個の記録:
select a.account_name, a.email, a.user_id, a.locale, a.firstname from v_accounts a where date(a.created_at) = date(current_date - interval '2 days')
しかし、私は私のスクリプトを実行したときに、私は、クエリの結果としてNone
を持っています。これは私のスクリプトclass
です:
import psycopg2
class MyDatabase(object):
db_name='you'
user='will'
pw='never'
host='know'
port='it'
def __init__(self, db=db_name, user=user, password=pw, host=host, port=port):
"""Connection to db - creation of the cursor"""
try:
self.baseDonn = psycopg2.connect(host=host, port=port, database=db, user=user,password=password)
except Exception as err:
print('La connexion avec la base de données à échoué : Erreur détéctée : %s' % err)
else:
self.cursor=self.baseDonn.cursor() # Création du curseur
def get_data_from_accounts(self,nb_days):
''' Method that retrieves data from all accounts that were created nb_days before today '''
sql="select a.account_name,u.email, u.user_id,u.locale, u.firstname from accounts a inner join account_users au on a.account_id=au.account_id inner join users u on au.user_id=u.user_id where date(a.created_at) = date(current_date - interval '%s days');"
print(sql)
data=(nb_days,)
try:
records = self.cursor.execute(sql,data)
print('cursor-execute={}'.format(records))
except Exception as err:
print("La requete n'est pas passée, erreur={}".format(err))
else:
return records
これは、主要部分
from my_db import MyDatabase
database=MyDatabase()
# On va récupérer les données des nouveaux accounts d'y a un jours
days_ago_2=database.get_data_from_accounts(2)
for personne_1 in days_ago_2:
# data
#account_name=personne_1[0]
email=personne_1[1]
user_id=personne_1[2]
locale=personne_1[3]
firstname='' if personne_1[4] is None else personne_1[4]
language = locale.split('_')[1]
activation_token= database.get_activation_token(user_id)
subject = call_to_template2(firstname, language,activation_token)['subject']
content = call_to_template2(firstname, language,activation_token)['content']
print('EMAIL={} - ID={} - LANGUE={} - FIRSTNAME={}'.format(email, user_id, language, firstname))
#send_data(qui_envoie, email, subject, content, token, language)
そして、私のエラーNone object is not iterable
のでラインfor personne_1 in days_ago_2:
上です。そして、私はクエリの結果を見ました。get_data_from_accounts(2) = None
あなたのSQL文字列の形成は私には奇妙なようです。 "print(sql)"は出力としてあなたに何を与えるのですか? また、同じ問題があった人からの回答を得たい場合は、より正確なタイトルを付ける必要があります。あなたのタイトルは広すぎます。 – Carele