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

Python Email sender

09.10.2024, 14:52. Показов 821. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru