从数据库中检索数据并通过邮件发送
Retrieving data from a DB and send it via mail
我正在创建一个脚本,它从数据库中获取一些数据,然后通过邮件发送。不幸的是,我被一些看起来很容易做的事情困住了。
如果数据库中只有一个条目,它就可以完美运行(例如:18/10/18 - 做数学练习)但是如果有多个条目,它们就不会出现,我考虑过使用 while 循环但由于我必须将所有条目保存在同一个变量中,所以我无法让它工作。我分享下面的代码:
# Enviar correu Python 3.6 (NO ANOMENAR EMAIL.PY)
import smtplib, pymysql.cursors, secrets, re, datetime
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from time import strftime
def dbb():
connection = pymysql.connect(host='X',
user='root',
password='X',
db='deuresc',
charset='utf8mb4',
cursorclass=pymysql.cursors.DictCursor)
try:
with connection.cursor() as cursor:
# Llegim tots els recordatoris
dataactual = strftime('%Y-%m-%d')
data = datetime.datetime.strptime(dataactual, "%Y-%m-%d")
datafinal = data + datetime.timedelta(days=1)
sql = "SELECT * FROM `deures` WHERE `data`=%s"
cursor.execute(sql, datafinal)
resultat = cursor.fetchall()
for row in resultat:
data = str(row['data'])
print(data)
tasca = str(row['tasca'])
print(tasca)
# It prints all the values but it doesn't send them below.
fromaddr = "X"
PASSWORD = "X"
welcome = ['Jefe', 'Gery', 'Boss', 'Gary']
# Misstage del correu
SUBJECT = "Recordatori deures " + data
body = "Bon dia " + secrets.choice(welcome) + ',' + '\n' + 'Tens les següents tasques programades per demà: ' + '\n' + data + ' ' + tasca
toaddr = "X"
try:
msg = MIMEMultipart()
msg['From'] = fromaddr
msg['To'] = toaddr
msg['Subject'] = SUBJECT
msg.attach(MIMEText(body, 'plain'))
# Detalles del servidor de correu (Gmail, SMTP, Port: 587, TLS)
server = smtplib.SMTP('smtp.gmail.com', 587)
server.starttls()
server.login(fromaddr, PASSWORD)
text = msg.as_string()
server.sendmail(fromaddr, toaddr, text)
server.quit()
print("S'ha enviat el recordatori a '" + toaddr + "' satisfactoriament!")
except:
print("S'ha produït un error!")
finally:
connection.close()
在此先感谢您的帮助,
您正在遍历结果并在循环内分配值 data
和 tasca
。循环完成后,这两个变量将只包含打印的每个值的最后一个。
检查:
>>> for value in range(3):
... print(value)
...
0
1
2
>>> print(value)
2
如果要打印所有值,则必须将它们存储在某个地方。
你可能想要这样的东西
datas = [] # list to remember the data values
tascas = [] # list to remember the tasca values
for row in resultat:
data = str(row['data'])
print(data)
datas.append(data) # store this data in the list
tasca = str(row['tasca'])
print(tasca)
tascas.append(tasca) # store this tasca in the list
... 稍后在代码中
body = "Bon dia " + secrets.choice(welcome) + ',' + '\n' + \
'Tens les següents tasques programades per demà: ' + '\n' + \
'\n'.join(datas) + ' ' + '\n'.join(tascas)
如果您希望在电子邮件中将这些值并排打印,则收集循环可能应该类似于
data_tasca = [] # list to remember data/tasca pairs
for row in resultat:
...
data_tasca.append(' '.join([data, tasca]))
然后在 body
赋值中收集来自 data_tasca
的行,类似于上面收集来自 datas
和 tascas
的值的方式。
顺便说一句,您应该将不使用 cursor
的代码移到 with
子句之外,即在 cursor.fetchall()
.[=23 之后缩进代码=]
我正在创建一个脚本,它从数据库中获取一些数据,然后通过邮件发送。不幸的是,我被一些看起来很容易做的事情困住了。
如果数据库中只有一个条目,它就可以完美运行(例如:18/10/18 - 做数学练习)但是如果有多个条目,它们就不会出现,我考虑过使用 while 循环但由于我必须将所有条目保存在同一个变量中,所以我无法让它工作。我分享下面的代码:
# Enviar correu Python 3.6 (NO ANOMENAR EMAIL.PY)
import smtplib, pymysql.cursors, secrets, re, datetime
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from time import strftime
def dbb():
connection = pymysql.connect(host='X',
user='root',
password='X',
db='deuresc',
charset='utf8mb4',
cursorclass=pymysql.cursors.DictCursor)
try:
with connection.cursor() as cursor:
# Llegim tots els recordatoris
dataactual = strftime('%Y-%m-%d')
data = datetime.datetime.strptime(dataactual, "%Y-%m-%d")
datafinal = data + datetime.timedelta(days=1)
sql = "SELECT * FROM `deures` WHERE `data`=%s"
cursor.execute(sql, datafinal)
resultat = cursor.fetchall()
for row in resultat:
data = str(row['data'])
print(data)
tasca = str(row['tasca'])
print(tasca)
# It prints all the values but it doesn't send them below.
fromaddr = "X"
PASSWORD = "X"
welcome = ['Jefe', 'Gery', 'Boss', 'Gary']
# Misstage del correu
SUBJECT = "Recordatori deures " + data
body = "Bon dia " + secrets.choice(welcome) + ',' + '\n' + 'Tens les següents tasques programades per demà: ' + '\n' + data + ' ' + tasca
toaddr = "X"
try:
msg = MIMEMultipart()
msg['From'] = fromaddr
msg['To'] = toaddr
msg['Subject'] = SUBJECT
msg.attach(MIMEText(body, 'plain'))
# Detalles del servidor de correu (Gmail, SMTP, Port: 587, TLS)
server = smtplib.SMTP('smtp.gmail.com', 587)
server.starttls()
server.login(fromaddr, PASSWORD)
text = msg.as_string()
server.sendmail(fromaddr, toaddr, text)
server.quit()
print("S'ha enviat el recordatori a '" + toaddr + "' satisfactoriament!")
except:
print("S'ha produït un error!")
finally:
connection.close()
在此先感谢您的帮助,
您正在遍历结果并在循环内分配值 data
和 tasca
。循环完成后,这两个变量将只包含打印的每个值的最后一个。
检查:
>>> for value in range(3):
... print(value)
...
0
1
2
>>> print(value)
2
如果要打印所有值,则必须将它们存储在某个地方。
你可能想要这样的东西
datas = [] # list to remember the data values
tascas = [] # list to remember the tasca values
for row in resultat:
data = str(row['data'])
print(data)
datas.append(data) # store this data in the list
tasca = str(row['tasca'])
print(tasca)
tascas.append(tasca) # store this tasca in the list
... 稍后在代码中
body = "Bon dia " + secrets.choice(welcome) + ',' + '\n' + \
'Tens les següents tasques programades per demà: ' + '\n' + \
'\n'.join(datas) + ' ' + '\n'.join(tascas)
如果您希望在电子邮件中将这些值并排打印,则收集循环可能应该类似于
data_tasca = [] # list to remember data/tasca pairs
for row in resultat:
...
data_tasca.append(' '.join([data, tasca]))
然后在 body
赋值中收集来自 data_tasca
的行,类似于上面收集来自 datas
和 tascas
的值的方式。
顺便说一句,您应该将不使用 cursor
的代码移到 with
子句之外,即在 cursor.fetchall()
.[=23 之后缩进代码=]