Как отправить электронное письмо в python для значений, извлеченных из базы данных - PullRequest
1 голос
/ 23 апреля 2020

Я пытаюсь отправить электронное письмо, используя smtplib для значений, извлеченных из базы данных mysql. Вот код:

db = pymysql.connect('localhost', 'root', 'Gandharv@4me', 'ashmita')
cursor = db.cursor()

sql_query = "SELECT * FROM employees1 WHERE fname = 'gandharv' "
cursor.execute(sql_query)
result = cursor.fetchall()
for row in result:
        firstname = row[0]
        lastname = row[1]
        role = row[2]
response = """ First Name : {}, Last Name: {}, Role : {} """.format(
        firstname, lastname, role)
mail = smtplib.SMTP('smtp.gmail.com', '587')
content="FirstName: "+firstname+" Lastname: " +lastname + "Role: ",role
mail.ehlo()
mail.starttls()
mail.login('abc@gmail.com', 'myPassword')
mail.sendmail('abc@gmail.com',
                  'bcd@gmail.com', content)
mail.close()
print(response)

Если я использую content = "knsdlkds", он работает нормально, но если я использую content = response или content = "FirstName:" + firstname + "Lastname:" + lastname + "Role:", роль. Это дает мне TypeError: ожидаемую строку или байтовоподобный объект. Может ли это быть решено кастом?

1 Ответ

0 голосов
/ 23 апреля 2020

у вас была опечатка в переменной содержимого. Можете ли вы проверить, работает ли это для вас.

HOST="localhost"
USER="root"
USER_PW="Gandharv@4me"
HOST_DB="ashmita"

gandharv = "VALUE_HERE"
sender = 'from@fromdomain.com'
debuglevel = 0

try:
    db = pymysql.connect(HOST, USER, USER_PW, HOST_DB)
    cursor = db.cursor()
    sql_query = "SELECT * FROM employees1 WHERE fname = '{0}' ".format(gandharv)
    cursor.execute(sql_query)
    result = cursor.fetchone()

    # Send Email
    firstname = result[0]
    lastname = result[1]
    role = result[2]
    receivers = ['to@todomain.com']

    response = " First Name : {0}, Last Name: {1}, Role : {2} ".format(firstname, lastname, role)

    try:
        smtp = SMTP()
        smtp.set_debuglevel(debuglevel)
        smtp.connect('YOUR.MAIL.SERVER', 26)
        smtp.login('USERNAME@DOMAIN', 'PASSWORD')
        smtp.sendmail(sender, receivers, response)
        smtp.quit()
        print(response)

    except SMTPException:
        print "Error: unable to send email"

except Exception as e:
    print "Error: {0}".format(e)
...