С Новым годом! Форум программистов, компьютерный форум, киберфорум
Python: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 06.09.2023
Сообщений: 9

Python Email sender

09.10.2024, 14:52. Показов 770. Ответов 4

Студворк — интернет-сервис помощи студентам
Доброго времени суток
Делаю "робота" для рассылки писем
при запуске из pycharm все работает корректно
Пробовал написать батник и поместил в автозагрузку, но не ничего не отрабатывает.
Пробовал еще запустить через cmd и точно такой же
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
import datetime
from email.mime.application import MIMEApplication
from email.mime.multipart import MIMEMultipart
 
import time
import openpyxl
import pyodbc
import smtplib
import schedule
import logging
 
import sql_queries
import config
 
 
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
logger = logging.getLogger(__name__)
 
 
class DataBaseConnector:
    def __init__(self, server, database):
        self.server = server
        self.database = database
 
    def connection(self):
        conn = pyodbc.connect('DRIVER={ODBC Driver 17 for SQL Server};SERVER='+self.server+';DATABASE='+self.database+';Trusted_Connection=yes')
        return conn
 
 
class ExcelGeneration:
    def __init__(self, data, cursor, file_name):
        self.data = data
        self.cursor = cursor
        self.file_name = file_name
 
    def generation_excel(self):
 
        wb = openpyxl.Workbook()
        sheet = wb.active
 
        #добавляем заголовки
        headers = [desc[0] for desc in self.cursor.description]
        sheet.append(headers)
 
        #Добавляем данные с базы
        for row in self.data:
            sheet.append(list(row))
        wb.save(self.file_name)
        return self.file_name
 
 
class EmailSender:
    def __init__(self, email_sender, email_recipient, subject,  attachment, smtp_server, smtp_port, email_password):
        self.email_sender = email_sender
        self.email_recipient = email_recipient
        self.subject = subject
        self.attachment = attachment
        self.smtp_server = smtp_server
        self.smtp_port = smtp_port
        self.email_password = email_password
 
    def send_email(self):
 
        msg = MIMEMultipart()
 
        msg['From'] = self.email_sender
        msg['To'] = ', '.join(self.email_recipient)
        msg['Subject'] = self.subject
 
 
        with open(self.attachment, 'rb') as f:
            self.attachment = MIMEApplication(f.read(), Name=self.attachment)
        msg.attach(self.attachment)
        server = smtplib.SMTP(self.smtp_server, self.smtp_port)
        server.login(self.email_sender, self.email_password)
        server.sendmail(self.email_sender, self.email_recipient, msg.as_string())
        server.quit()
 
 
class NewsLetters:
    def __init__(self, sql_server, DataBase, sql_query, email_sender, email_recipient, email_subject, smtp_server, smtp_port, email_password, file_name):
        self.sql_server = sql_server
        self.DataBase = DataBase
        self.sql_query = sql_query
        self.email_sender = email_sender
        self.email_recipient = email_recipient
        self.email_subject = email_subject
        self.smtp_server = smtp_server
        self.smtp_port = smtp_port
        self.email_password = email_password
        self.file_name = file_name
 
    def start(self):
        logger.info('Начало процесса NewsLetters')
 
        connector = DataBaseConnector(self.sql_server, self.DataBase)
        conn = connector.connection()
        cursor = conn.cursor()
        cursor.execute(self.sql_query)
        data = cursor.fetchall()
        logger.info('Успешно подключение к бд')
 
 
        generator = ExcelGeneration(data, cursor, self.file_name)
        attachment = generator.generation_excel()
        logger.info('Файл Excel сгенерирован успешно')
 
        sender = EmailSender(self.email_sender, self.email_recipient, self.email_subject, attachment, self.smtp_server, self.smtp_port, self.email_password)
        sender.send_email()
        logger.info('Письмо отправлено успешно')
 
def run():
 
    email = NewsLetters(config.sql_server, config.DataBase, sql_queries.sql_query, config.email_sender, sql_queries.email_recipient, sql_queries.email_subject, config.smtp_server, config.smtp_port, config.email_password, sql_queries.file_name)
    email.start()
 
def check_if_first_day_of_month():
 
    logger.info('Проверяем число')
    if datetime.date.today().day == 9:
        run()
    else:
        logger.info('Не сегодня ;)')
 
schedule.every().day.at("14:00").do(check_if_first_day_of_month)
 
 
 
while True:
    schedule.run_pending()
    time.sleep(1)

в батнике прописываю
Bash
1
2
3
@echo off
 
start /min  "path_to_file.py"
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.10.2024, 14:52
Ответы с готовыми решениями:

Картинка в тело письма email PYTHON на Linux
Добрейшего времени суток, друзья. Суть вопроса, мне нужно встроить картинку в тело письма(именно в само письмо, а не вложением к письму)...

Custom Email sender
Приветос, все не могу никак найти примеров, которые отходят от стандартных форм отправки писем с приложений Да, я знаю как сделать так...

Странность с Email::Sender и cgi
Здравствуйте! Пытаюсь отослать сообщение через use Email::Sender::Transport::SMTP (); Все отлично рработает если просто выполнять...

4
Заблокирован
09.10.2024, 22:29
Цитата Сообщение от krabnerab Посмотреть сообщение
в батнике прописываю
батник нужно доработать, нужно указать полный путь к питону и к скрипту, возможно поможет...
пример

Bash
1
"C:\Python39\python.exe" "C:\Scripts\send_emails.py"...
0
0 / 0 / 0
Регистрация: 06.09.2023
Сообщений: 9
10.10.2024, 10:09  [ТС]
Указывал полный путь к питону, но тоже не помогло.
0
Заблокирован
10.10.2024, 11:35
Цитата Сообщение от krabnerab Посмотреть сообщение
но тоже не помогло.
попробуйте логировать и посмотреть что происходит, так же убедитесь правильно ли прописаны названия и пути...
Bash
1
2
@echo off
"C:\Python39\python.exe" "C:\Scripts\send_emails.py" >> "C:\Scripts\newsletter.log" 2>&1
Добавлено через 3 минуты
Цитата Сообщение от krabnerab Посмотреть сообщение
@echo off
start /min  "path_to_file.py"
Можно его немного тоже модифицировать и вот так сделать:

Bash
1
2
@echo off
start "" /min "C:\Python39\python.exe" "C:\Scripts\send_emails.py" >> "C:\Scripts\newsletter.log" 2>&1
0
0 / 0 / 0
Регистрация: 06.09.2023
Сообщений: 9
15.10.2024, 17:11  [ТС]
если кому интересно, то проблема была не в батнике и не в коде, а в том что Microsooft видимо блочил python каким-то образом
переустановил python из microsoft store И все заработало
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.10.2024, 17:11
Помогаю со студенческими работами здесь

Кодировки в python при отправке email
в общем я отправляю сообщение вот такого содержания на почту себе 123 afk АеК 234 bgl БёЛ 345 chm ВжМ 456 din ГзН 567 ego ДиО ...

Email сервис не требующий подтверждения по номеру телефона и другому email
Доброго времени! Прошу прощения если не туда пишу! Несколько месяцев назад регистрировал почту на Gmail. Заходил пару раз, и оба...

Web-мастер (продвижение, разработка, контент). Ответы ждем на [email]info@airroc.com[/email]
Web-мастер (продвижение, разработка, контент). Ответы ждем на info@airroc.com Позиция: Руководитель старт-ап проекта www.airroc.com ...

Angular 6 + Firebase email-password authorisation. Email Verification
Есть некоторое приложение с необходимостью регистрации/авторизации (Firebase -email/password). При нажатии на условную кнопку...

Отправка файлов по имени (email.pdf) на email
Всем привет! Есть куча файлов (около 160) каждый файл называется именем e-maila на который должен быть отправлен. Как быстро их все...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru