-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathmain.py
More file actions
57 lines (42 loc) · 1.82 KB
/
main.py
File metadata and controls
57 lines (42 loc) · 1.82 KB
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
import asyncio
import logging
import datetime
import threading
import time
from config.config import api_id, api_hash
from config.sources import tg_channels
from services.event_reader import kassir
from services.news_reader import nnru, rbc
from services.tg_grabber import telegram_grabber
# Настройка логгера
logging.basicConfig(level=logging.INFO, filename="py_log.log", filemode="w",
format="%(asctime)s %(levelname)s %(message)s")
logger = logging.getLogger("myGrab")
async def safe_execute(task, task_name, semaphore):
async with semaphore:
try:
await task
except Exception as e:
logger.error(f"Ошибка при выполнении {task_name}: {e}")
async def main():
semaphore = asyncio.Semaphore(5)
tasks = [
asyncio.create_task(safe_execute(nnru(logger), "nnru", semaphore)),
asyncio.create_task(safe_execute(rbc(logger), "rbc", semaphore)),
asyncio.create_task(safe_execute(kassir(logger), "kassir", semaphore))
]
await asyncio.gather(*tasks)
def run_telegram_grabber():
asyncio.run(telegram_grabber("myGrab", api_id, api_hash, logger, tg_channels=tg_channels))
async def periodic_main():
while True:
logger.info(f"Запуск основных задач. Время: {datetime.datetime.now()}")
await main()
await asyncio.sleep(1800) # Ждем 30 минут перед следующим запуском
def run_main_periodically():
asyncio.run(periodic_main())
# Запуск telegram_grabber в отдельном потоке
#telegram_thread = threading.Thread(target=run_telegram_grabber)
#telegram_thread.start()
# Запуск main периодически в основном потоке
run_main_periodically()