CodeShadow – Telegram
CodeShadow
76 subscribers
181 photos
11 videos
7 files
127 links
👋 Я Артемий — преподаватель Python и фрилансер.

💻 Показываю, как код и нейросети помогают зарабатывать и упрощать работу.

🚀 Делюсь проектами, опытом и лайфхаками из реальной практики.

✍🏻 Вопросы и идеи: @MifmanRu
Download Telegram
Channel name was changed to «CodeShadow 💻»
Дополняем бота-органайзера напоминаниями

В прошлый раз мы сделали основу: заметки, теги и поиск. Теперь — добавляем напоминания, чтобы бот сам писал тебе в нужное время.

🗓 Мини-шаблон:
import asyncio
from datetime import datetime, timedelta

reminders = [] # [(user_id, text, time)]

@dp.message(commands=["remind"])
async def set_reminder(msg: types.Message):
# Пример: /remind Через 1 минуту Выпить кофе
parts = msg.text.split(" ", 3)
minutes, text = int(parts[1]), parts[2:]
remind_time = datetime.now() + timedelta(minutes=minutes)
reminders.append((msg.from_user.id, " ".join(text), remind_time))
await msg.answer(f" Напоминание через {minutes} мин!")

async def reminder_loop():
while True:
now = datetime.now()
for r in reminders[:]:
user_id, text, time = r
if now >= time:
await bot.send_message(user_id, f"🔔 Напоминание: {text}")
reminders.remove(r)
await asyncio.sleep(10)

asyncio.create_task(reminder_loop())


🚀 Теперь бот не просто хранит заметки, а помогает не забывать важное.
Дальше можно добавить:

✉️ экспорт напоминаний в файл

🗓 расписание на день/неделю

📌 автоповторы

#CodeShadow #TelegramBot #Python #aiogram #Кейс #Напоминания
Please open Telegram to view this post
VIEW IN TELEGRAM
111
🔎 Парсинг сайтов: быстрый старт

Парсинг — топ-задача на биржах. Например, собрать заголовки с сайта новостей:

code
import requests
from bs4 import BeautifulSoup

url = "https://site.com"
html = requests.get(url).text
soup = BeautifulSoup(html, "html.parser")

for h in soup.find_all("h2"):
print(h.text)


Клиенты часто заказывают именно такие штуки.

В последующих постах — автоматизация: как облегчить жизнь заказчику. Не пропустите!)
11
Channel name was changed to «CodeShadow»
🔥 Как автоматизировать учёт доходов на фрилансе

После пары проектов начинаешь тонуть в рутине: записывать название заказа, сумму, дату… Каждый раз открывать Google Таблицы и забивать всё руками — скука.

Я быстро устал от этого и решил, что за меня будет работать Python.

🎯 Кейс: учёт заказов

Есть файл orders.json с заказами:
[
{"noscript": "Telegram-бот для магазина", "price": 12000, "date": "2025-09-01"},
{"noscript": "Парсер новостей", "price": 8000, "date": "2025-09-05"},
{"noscript": "Автопостинг в ВК", "price": 10000, "date": "2025-09-10"}
]


Скрипт берёт данные из файла и автоматически отправляет их в Google Таблицу.

📌 Что нужно:
Python 3
библиотека gspread
Google API-ключ (.json) с доступом к таблице

🚀 Код:
import json
import gspread
from oauth2client.service_account import ServiceAccountCredentials

scope = ["https://spreadsheets.google.com/feeds",
"https://www.googleapis.com/auth/drive"]

creds = ServiceAccountCredentials.from_json_keyfile_name("service_account.json", scope)
client = gspread.authorize(creds)

sheet = client.open("Финансы_Фрилансера").sheet1

with open("orders.json", "r", encoding="utf-8") as f:
orders = json.load(f)

for order in orders:
sheet.append_row([order["date"], order["noscript"], order["price"]])

print(" Готово! Данные в таблице.")


🧠 Что можно докрутить:
1. считать итог за месяц
2. конвертировать доход в валюты
2. генерировать PDF-отчёты
3. связать с Telegram-ботом и получать статистику по команде


💡Автоматизация — это про свободу. Один раз написал скрипт → и больше не тратишь время на однообразные действия.


☕️ А какие процессы тебе хотелось бы переложить на код?
Please open Telegram to view this post
VIEW IN TELEGRAM
11
Channel photo updated
Друзья, какой мини-скрипт вы хотите освоить в этом месяце? 😎 Выбирайте, а я подготовлю пример! 🧑‍💻
Голосуем до 20 сентября!
Final Results
27%
Автоматизация задач (например, ренейминг файлов)
53%
🖥 Парсинг сайтов для данных
40%
✉️ Массовая рассылка писем
7%
💬 Другое (пишите в комментариях!)
2
CodeShadow pinned «Друзья, какой мини-скрипт вы хотите освоить в этом месяце? 😎 Выбирайте, а я подготовлю пример! 🧑‍💻
Голосуем до 20 сентября!
»
🎨 Как генерировать картинки на Python

Программирование — это не только про таблицы и цифры. Python умеет творить искусство

Например, я попробовал сделать скрипт, который рисует абстрактные узоры и сохраняет их в PNG. Получается что-то вроде «генеративного искусства».


🎯 Кейс: рисуем абстракцию

📌 Что нужно:
⭐️ Python 3
⭐️ библиотека Pillow

🚀 Код:
from PIL import Image, ImageDraw
import random

# создаём пустое изображение
img = Image.new("RGB", (500, 500), "white")
draw = ImageDraw.Draw(img)

# рисуем случайные круги
for _ in range(50):
x1 = random.randint(0, 500)
y1 = random.randint(0, 500)
x2 = x1 + random.randint(20, 100)
y2 = y1 + random.randint(20, 100)
color = (random.randint(0, 255), random.randint(0, 255), random.randint(0, 255))
draw.ellipse([x1, y1, x2, y2], fill=color)

img.save("abstract.png")
print(" Картинка готова!")


🧠 Что можно докрутить:

⚙️ Добавить разные фигуры (линии, прямоугольники, узоры).
⚙️ Генерировать серию картинок и собирать из них коллекцию.
⚙️ Сделать «генератор аватарок» для профиля.

💡 Программирование может быть не только полезным, но и красивым.

☕️ А ты бы попробовал написать свой генератор картинок?
Please open Telegram to view this post
VIEW IN TELEGRAM
21
⚙️ Автоматизация: твой главный козырь

Программисты-фрилансеры ценятся за то, что снимают рутину.
Пример: удаление старых файлов на сервере клиента.

code
import os, time

folder = "logs"
now = time.time()

for f in os.listdir(folder):
path = os.path.join(folder, f)
if os.path.isfile(path) and now - os.path.getmtime(path) > 7*86400:
os.remove(path)


Просто, но клиент доволен.

В дальнейшем обсудим работу с API, ведь это частая необходимость.
11
🔌 Работа с API: пример погоды

Фрилансеру часто приходится работать с API.
Пример: получаем данные о погоде через OpenWeather.

import requests

API_KEY = "ВАШ_API_КЛЮЧ" # получите на openweathermap.org
city = "Moscow"
url = f"https://api.openweathermap.org/data/2.5/weather?q={city}&appid={API_KEY}&units=metric&lang=ru"

response = requests.get(url)
data = response.json()

if response.status_code == 200:
temp = data["main"]["temp"]
weather = data["weather"][0]["denoscription"]
print(f"Погода в {city}: {temp}°C, {weather}")
else:
print("Ошибка:", data.get("message", "Не удалось получить данные"))


API = умение подключать сервисы. Это востребовано.

Далее — где хранить данные: базы, JSON, CSV.
1
⚡️ Автоматизация Google Таблиц на Python: отчёты без боли

Недавно я уже делал пост про автоматизацию Google Таблиц с Python — там закидывал доходы фрилансера прямо из JSON. Сегодня продолжу тему и разберу ещё один кейс, который может быть полезен каждому.

🎯 Кейс: статистика из чата в таблицу

Представь, ты ведёшь Telegram-канал или чат. Каждый день хочется видеть простую статистику:
сколько человек подписалось
сколько сообщений написали
сколько лайков накликали
Обычно это где-то лежит в API, и ты смотришь раз в неделю… Но почему бы не сделать так, чтобы данные сами залетали в Google Таблицу? 😀

🛠 Что понадобится
☀️Python 3
☀️Библиотека gspread (работа с Google Sheets)
☀️Google API ключ (JSON-файл с доступом к таблицам)

🚀 Код-пример
import gspread
from oauth2client.service_account import ServiceAccountCredentials
import datetime

# Доступ к Google
scope = ["https://spreadsheets.google.com/feeds",
         "https://www.googleapis.com/auth/drive"]

creds = ServiceAccountCredentials.from_json_keyfile_name("service_account.json", scope)
client = gspread.authorize(creds)

# Открываем таблицу
sheet = client.open("Статистика_канала").sheet1

# Данные для примера (на деле можно тянуть из Telegram API)
today = datetime.date.today().strftime("%Y-%m-%d")
new_users = 15
messages = 120
likes = 340

# Записываем строку
sheet.append_row([today, new_users, messages, likes])

print(" Статистика обновлена!")


🔥 Чем это круто
каждый день таблица сама пополняется свежими цифрами
есть история за каждый день, удобно строить графики
можно сразу видеть динамику: растёшь или нет

💡 Где ещё применить
✔️отчёты по заказам для фрилансера
✔️база клиентов (новые заявки падают автоматом)
✔️контент-план для блога
✔️трекер расходов/доходов 😀

Автоматизация таблиц = освобождение головы от рутины. Настроил один раз → и дальше система сама работает.

➡️ Напиши в комментах: а какие данные ты бы хотел видеть в своей Google Таблице каждый день?
Please open Telegram to view this post
VIEW IN TELEGRAM
11
В последнее время дни сильно загружены и часто путаюсь в расписании 😵

Решил для себя сделать бота-планёра, чтобы не забывать о занятиях и дедлайнах.

Пишите в комменты, если для вас эта тема актуальна 👨‍💻
Please open Telegram to view this post
VIEW IN TELEGRAM
51
Кейс: Telegram-бот для контент плана

У фрилансеров и SMM-щиков часто одна головная боль — контент. Идеи постов есть, но они теряются в заметках, Excel или просто в голове.
Что если у тебя будет бот, который сам раскладывает идеи по дням и формирует план публикаций?


Это реально полезный инструмент:

☀️удобно показывать клиенту (он видит расписание постов)

☀️можно интегрировать с Google Таблицами

☀️легко расширить до автопостинга.

⚙️ Мини-версия на Python (aiogram 3)
import datetime
from aiogram import Bot, Dispatcher, types
from aiogram.filters import Command
import asyncio, os

API_TOKEN = os.getenv("BOT_TOKEN")
bot = Bot(API_TOKEN)
dp = Dispatcher()

ideas = {} # {user_id: [(date, text), ...]}

@dp.message(Command("add"))
async def add_idea(msg: types.Message):
# Пример: /add 2025-09-20 Идея поста про Python
try:
parts = msg.text.split(" ", 2)
date = datetime.datetime.strptime(parts[1], "%Y-%m-%d").date()
text = parts[2]
ideas.setdefault(msg.from_user.id, []).append((date, text))
await msg.answer(f" Добавлено: {text} ({date})")
except:
await msg.answer("⚠️ Формат: /add YYYY-MM-DD ТЕКСТ")

@dp.message(Command("plan"))
async def show_plan(msg: types.Message):
user_ideas = ideas.get(msg.from_user.id, [])
if not user_ideas:
await msg.answer("📭 План пуст")
else:
user_ideas.sort(key=lambda x: x[0])
text = "📅 Твой контент-план:\n\n"
for d, t in user_ideas:
text += f"— {d}: {t}\n"
await msg.answer(text)

async def main():
await dp.start_polling(bot)

if __name__ == "__main__":
asyncio.run(main())


🧠 Что можно улучшить

☀️добавить повторяющиеся посты (например, каждую пятницу «разбор кейсов»)

☀️сделать экспорт в Google Sheets или Excel

☀️прикрутить напоминания (бот сам пишет утром: «сегодня нужно опубликовать пост»)

☀️добавить категории: «статьи», «кейсы», «мемы» 💪

🔥 Почему это круто

✔️ты решаешь реальную задачу для клиентов

✔️можно сразу продавать как отдельный сервис или использовать самому

✔️в портфолио это выглядит очень убедительно (бот с датами, хранилищем и удобным интерфейсом)

⁉️ А у тебя уже есть свой контент-план или ты пока публикуешь «по вдохновению»?


#CodeShadow #TelegramBot #Python #Фриланс
Please open Telegram to view this post
VIEW IN TELEGRAM
51
CodeShadow
В последнее время дни сильно загружены и часто путаюсь в расписании 😵 Решил для себя сделать бота-планёра, чтобы не забывать о занятиях и дедлайнах. Пишите в комменты, если для вас эта тема актуальна 👨‍💻
Пишу проект бота-планёра для телеграм. Скоро выйдет пост на тему данного бота 💎

Вкратце: можно делать записи по задачам, выставлять дату и время, есть фиксированные задачи по будням и оповещения, а также отчётность за неделю 👨‍💻
Please open Telegram to view this post
VIEW IN TELEGRAM
2
🚀 Мой новый проект: Telegram-бот для планирования задач и расписания

Привет, друзья! Недавно я упоминал, что дни стали слишком загруженными, и я часто путаюсь в дедлайнах, встречах и повторяющихся задачах. Как фрилансер, я устал от заметок в телефоне и напоминаний в календаре — они не всегда срабатывают вовремя. Решил: пора написать своего бота-планировщика, который будет держать всё под контролем.

Это не просто напоминалка, а полноценный инструмент для фрилансеров, студентов или SMM-щиков. Бот поможет организовать разовые задачи (с датой, временем и описанием) и фиксированное расписание (например, еженедельные занятия или встречи). Плюс напоминания, отчёты и простая интеграция с Telegram.

👨‍💻 Кейс: от хаоса к порядку

Представь: добавляешь задачу "/add_task Менторство с клиентом 2025-09-25 14:00", бот сохраняет её, напоминает за 30 минут (или по твоим настройкам) и даже формирует отчёт за неделю — сколько задач выполнено, сколько висит. Для повторяющихся вещей (типа "урок по Python каждую среду в 18:00") есть отдельный режим с деактивацией по команде.

Бот работает на Python с библиотеками telebot, SQLAlchemy (для базы данных) и APScheduler (для напоминаний). Всё в одном проекте, без лишних зависимостей.


📌 Что нужно для запуска:
⭐️ Python 3
⭐️ Библиотеки: telebot, sqlalchemy, apscheduler, python-dotenv, pytz
⭐️ База: SQLite (или PostgreSQL для продакшена)
⭐️ Telegram API токен


🔴 Структура проекта (пока без полного кода — разберём в следующих постах)

—config.py: настройки (токен, таймзона, БД)
—models.py: модели задач и расписания (SQLAlchemy)
—db.py: подключение к БД
—utils.py: хелперы (парсинг дат, клавиатуры)
—scheduler.py: планировщик напоминаний
—bot_handlers.py: обработчики сообщений (добавление задач, настройки, отчёты)
—main.py: запуск бота и инициализация


В следующих постах разберём код по частям: от базы данных до напоминаний. Если тема зацепит — сделаю репозиторий на GitHub.

🧠 Что можно докрутить:
• Интеграцию с Google Calendar для синхронизации.
• Голосовые заметки для добавления задач.
• Графики отчётов в PNG (через Matplotlib).
• Мультипользовательский режим для команд.


Это не просто бот — это инструмент, который сэкономит часы на рутине. Я уже тестирую на себе, и это реально упрощает жизнь. 💪

☕️ А ты используешь ботов для планирования? Что бы добавил в такой проект?


#CodeShadow #TelegramBot #Python #Планировщик #Фриланс
Please open Telegram to view this post
VIEW IN TELEGRAM
31
📊 Хранение данных: куда девать результаты?

Фрилансер обязан уметь сохранять данные.
Пример — CSV-файл:

code
import csv

data = [("Анна", 90), ("Иван", 75)]

with open("scores.csv", "w", newline="") as f:
writer = csv.writer(f)
writer.writerows(data)


Аналогично можно работать с JSON и SQLite.

Далее — советы по GitHub и портфолио.
2👀1
По результатам опроса, парсинг сайтов самый популярный 😎

В качестве примера парсинга будем писать скрипт для парсинга погоды с сайта www.gismeteo.ru 🖥
Please open Telegram to view this post
VIEW IN TELEGRAM
2
🚀 Разбор Telegram-бота: Часть 1 — База данных и модели (SQLAlchemy)

Привет, кодеры! В прошлом посте я рассказал о своём новом проекте — Telegram-боте для планирования задач и расписания. Он помогает фрилансерам и студентам держать дела в порядке: разовые задачи с напоминаниями, еженедельные занятия, отчёты и настройки. Бот на Python, с использованием telebot для интерфейса, APScheduler для тайминга и SQLAlchemy для хранения данных.

Сегодня начинаем разбирать код по частям, как обещал. Стартуем с фундамента: базы данных. Почему SQLAlchemy? Она гибкая, поддерживает разные БД (SQLite для теста, PostgreSQL для продакшена), и ORM делает работу с данными как с объектами Python — удобно и без сырого SQL.


🗂 Структура: db.py и models.py

Сначала config.py (там настройки, включая URL для БД). Вот базовый snippet:

# config.py
import os
from dotenv import load_dotenv
import pytz

load_dotenv()

BOT_TOKEN = os.getenv("BOT_TOKEN") # обязательно
DATABASE_URL = os.getenv("DATABASE_URL", "sqlite:///planner.db")
TIMEZONE = os.getenv("TIMEZONE", "Europe/Moscow")
TZ = pytz.timezone(TIMEZONE)


DATABASE_URL — это строка подключения. Для SQLite просто файл, для Postgres — 'postgresql://user:pass@host/db'.

.env файл хранит токен и секреты (не коммить в Git!).

Теперь db.py: создаём движок и сессию SQLAlchemy.

# db.py
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker, scoped_session
from config import DATABASE_URL

engine = create_engine(DATABASE_URL, echo=False, future=True)
SessionLocal = scoped_session(sessionmaker(bind=engine, autoflush=False, autocommit=False))


SessionLocal — это фабрика сессий. Мы используем scoped_session для thread-safety (важно для бота с многопоточностью).

Ключевой файл —
models.py. Здесь определяем таблицы: пользователи, задачи и расписание (классы/занятия). Используем Enum для статусов задач.

# models.py (фрагмент)
from sqlalchemy import Column, Integer, String, DateTime, Boolean, ForeignKey, Text, Enum, Time
from sqlalchemy.orm import declarative_base, relationship
import enum
from datetime import datetime, time

Base = declarative_base()

class TaskStatus(enum.Enum):
pending = "pending"
done = "done"

class User(Base):
__tablename__ = "users"
id = Column(Integer, primary_key=True, index=True) # internal id
tg_id = Column(Integer, unique=True, index=True, nullable=False) # telegram user id
name = Column(String, nullable=True)
default_remind_minutes = Column(Integer, default=30) # default reminder before event in minutes

tasks = relationship("Task", back_populates="user", cascade="all, delete-orphan")
classes = relationship("ClassSchedule", back_populates="user", cascade="all, delete-orphan")

class Task(Base):
__tablename__ = "tasks"
id = Column(Integer, primary_key=True, index=True)
user_id = Column(Integer, ForeignKey("users.id", ondelete="CASCADE"), nullable=False)
noscript = Column(String, nullable=False)
denoscription = Column(Text, nullable=True)
starts_at = Column(DateTime, nullable=False, index=True) # <- timezone=True
remind_before_minutes = Column(Integer, nullable=True)
status = Column(Enum(TaskStatus), default=TaskStatus.pending)

user = relationship("User", back_populates="tasks")

# ClassSchedule для еженедельных занятий (фрагмент)
class ClassSchedule(Base):
__tablename__ = "class_schedules"
id = Column(Integer, primary_key=True, index=True)
user_id = Column(Integer, ForeignKey("users.id", ondelete="CASCADE"), nullable=False)
noscript = Column(String, nullable=False)
weekday = Column(Integer, nullable=False) # 0..6
start_time = Column(Time, nullable=False, index=True)
duration_minutes = Column(Integer, default=90)
location = Column(String, nullable=True)
active = Column(Boolean, default=True)
remind_before_minutes = Column(Integer, nullable=True)

user = relationship("User", back_populates="classes")
Please open Telegram to view this post
VIEW IN TELEGRAM
21
Объясню:
— User — базовая модель с Telegram ID и дефолтным временем напоминания.
— Task — разовая задача: заголовок, описание, дата/время, статус (pending/done), напоминание.
— ClassSchedule — фиксированное расписание: день недели (0=Пн), время старта, длительность, локация. Активно/неактивно для деактивации без удаления.
— Связи: one-to-many (пользователь имеет много задач/занятий), с каскадным удалением.


В main.py инициализируем БД:

# main.py (фрагмент)
from db import engine, SessionLocal
from models import Base

def init_db():
Base.metadata.create_all(bind=engine)

# ... потом запуск бота


Это создаст таблицы при старте. Для миграций в проде используйте Alembic, но для MVP хватит.

⚙️ Советы:
- Храните даты в UTC, но в коде используйте pytz для локальной зоны (Europe/Moscow по дефолту).
- Индексы на starts_at и start_time ускорят запросы по времени.
- Cascade="all, delete-orphan" — автоматически удаляет задачи при удалении юзера (хотя в боте юзеры не удаляются).


🧩🧩🧩🧩🧩🧩🧩🧩
🧩🧩🧩🧩🧩🧩🧩🧩
🧩🧩🧩🧩🧩🧩🧩🧩
🧩🧩🧩🧩🧩🧩🧩🧩
🧩🧩🧩🧩🧩🧩🧩🧩
🧩🧩🧩🧩🧩🧩🧩🧩🧩
В следующем посте разберём utils.py и scheduler.py — хелперы, парсинг дат и как настроить напоминания с APScheduler. Если есть вопросы по БД — пишите в комментах!

🧠 Что думаешь: SQLite хватит для такого бота или сразу на Postgres? Делитесь опытом!

#CodeShadow #TelegramBot #Python #SQLAlchemy #Планировщик
Please open Telegram to view this post
VIEW IN TELEGRAM
21