#YOLOv8 #ComputerVision #TrafficManagement #Python #AI #SmartCity
Lesson: Detecting Traffic Congestion in Road Lanes with YOLOv8
This tutorial will guide you through building a system to monitor traffic on a highway from a video feed. We'll use YOLOv8 to detect vehicles and then define specific zones (lanes) to count the number of vehicles within them, determining if a lane is congested.
---
We need to install
Create a Python script (e.g.,
---
We'll load a pre-trained YOLOv8 model, which is excellent at detecting common objects like cars, trucks, and buses. The most critical part of this step is defining the zones of interest (our lanes) as polygons on the video frame. You will need to adjust these coordinates to match the perspective of your specific video.
You will also need a video file, for example,
---
This is the core of our program. We will loop through each frame of the video, run vehicle detection, and then check if the center of each detected vehicle falls inside our predefined lane polygons. We will keep a count for each lane.
(Note: The code below should be placed inside the
---
Lesson: Detecting Traffic Congestion in Road Lanes with YOLOv8
This tutorial will guide you through building a system to monitor traffic on a highway from a video feed. We'll use YOLOv8 to detect vehicles and then define specific zones (lanes) to count the number of vehicles within them, determining if a lane is congested.
---
#Step 1: Project Setup and DependenciesWe need to install
ultralytics for YOLOv8 and opencv-python for video and image processing. numpy is also essential for handling the coordinates of our detection zones.pip install ultralytics opencv-python numpy
Create a Python script (e.g.,
traffic_monitor.py) and import the necessary libraries.import cv2
import numpy as np
from ultralytics import YOLO
# Hashtags: #Setup #Python #OpenCV #YOLOv8
---
#Step 2: Model Loading and Lane DefinitionWe'll load a pre-trained YOLOv8 model, which is excellent at detecting common objects like cars, trucks, and buses. The most critical part of this step is defining the zones of interest (our lanes) as polygons on the video frame. You will need to adjust these coordinates to match the perspective of your specific video.
You will also need a video file, for example,
traffic_video.mp4.# Load a pre-trained YOLOv8 model (yolov8n.pt is small and fast)
model = YOLO('yolov8n.pt')
# Path to your video file
VIDEO_PATH = 'traffic_video.mp4'
# Define the polygons for two lanes.
# IMPORTANT: You MUST adjust these coordinates for your video's perspective.
# Each polygon is a numpy array of [x, y] coordinates.
LANE_1_POLYGON = np.array([[20, 400], [450, 400], [450, 250], [20, 250]], np.int32)
LANE_2_POLYGON = np.array([[500, 400], [980, 400], [980, 250], [500, 250]], np.int32)
# Define the congestion threshold. If vehicle count > this, the lane is congested.
CONGESTION_THRESHOLD = 10
# Hashtags: #Configuration #AIModel #SmartCity
---
#Step 3: Main Loop for Detection and CountingThis is the core of our program. We will loop through each frame of the video, run vehicle detection, and then check if the center of each detected vehicle falls inside our predefined lane polygons. We will keep a count for each lane.
cap = cv2.VideoCapture(VIDEO_PATH)
while cap.isOpened():
success, frame = cap.read()
if not success:
break
# Run YOLOv8 inference on the frame
results = model(frame)
# Initialize vehicle counts for each lane for the current frame
lane_1_count = 0
lane_2_count = 0
# Process detection results
for r in results:
for box in r.boxes:
# Check if the detected object is a vehicle
class_id = int(box.cls[0])
class_name = model.names[class_id]
if class_name in ['car', 'truck', 'bus', 'motorbike']:
# Get bounding box coordinates
x1, y1, x2, y2 = map(int, box.xyxy[0])
# Calculate the center point of the bounding box
center_x = (x1 + x2) // 2
center_y = (y1 + y2) // 2
# Check if the center point is inside Lane 1
if cv2.pointPolygonTest(LANE_1_POLYGON, (center_x, center_y), False) >= 0:
lane_1_count += 1
# Check if the center point is inside Lane 2
elif cv2.pointPolygonTest(LANE_2_POLYGON, (center_x, center_y), False) >= 0:
lane_2_count += 1
# Hashtags: #RealTime #ObjectDetection #VideoProcessing
(Note: The code below should be placed inside the
while loop of Step 3)---
#Step 4: Visualization and Displaying Results❤3
#TelegramBot #Python #SQLite #DataExport #CSV #API
Lesson: Creating a Telegram Bot to Export Channel Members to a CSV File
This tutorial guides you through building a Telegram bot from scratch. When added as an administrator to a channel, the bot will respond to an
IMPORTANT NOTE: Due to Telegram's privacy policy, bots CANNOT access users' phone numbers. This field will be marked as "N/A".
---
First, create a bot via the @BotFather on Telegram. Send it the
Next, set up your Python environment. Install the necessary library:
Create a new Python file named
---
To fulfill the requirement of using a database, we will log every export request. Create a new file named
---
Now, we'll write the core function in
Lesson: Creating a Telegram Bot to Export Channel Members to a CSV File
This tutorial guides you through building a Telegram bot from scratch. When added as an administrator to a channel, the bot will respond to an
/export command from the channel owner, exporting the list of members (Username, User ID, etc.) to a CSV file and storing a log of the action in a SQLite database.IMPORTANT NOTE: Due to Telegram's privacy policy, bots CANNOT access users' phone numbers. This field will be marked as "N/A".
---
#Step 1: Bot Creation and Project SetupFirst, create a bot via the @BotFather on Telegram. Send it the
/newbot command, follow the instructions, and save the HTTP API token it gives you.Next, set up your Python environment. Install the necessary library:
python-telegram-bot.pip install python-telegram-bot
Create a new Python file named
bot.py and add the basic structure. Replace 'YOUR_TELEGRAM_API_TOKEN' with the token you got from BotFather.import logging
from telegram import Update
from telegram.ext import Application, CommandHandler, ContextTypes
# Enable logging
logging.basicConfig(format="%(asctime)s - %(name)s - %(levelname)s - %(message)s", level=logging.INFO)
TOKEN = 'YOUR_TELEGRAM_API_TOKEN'
def main() -> None:
"""Start the bot."""
application = Application.builder().token(TOKEN).build()
# We will add command handlers here in the next steps
# application.add_handler(CommandHandler("export", export_members))
print("Bot is running...")
application.run_polling()
if __name__ == "__main__":
main()
# Hashtags: #Setup #TelegramAPI #PythonBot #BotFather
---
#Step 2: Database Setup for Logging (database.py)To fulfill the requirement of using a database, we will log every export request. Create a new file named
database.py. This separates our data logic from the bot logic.import sqlite3
from datetime import datetime
DB_NAME = 'bot_logs.db'
def setup_database():
"""Creates the database table if it doesn't exist."""
conn = sqlite3.connect(DB_NAME)
cursor = conn.cursor()
cursor.execute('''
CREATE TABLE IF NOT EXISTS export_logs (
id INTEGER PRIMARY KEY AUTOINCREMENT,
chat_id INTEGER NOT NULL,
chat_title TEXT,
requested_by_id INTEGER NOT NULL,
requested_by_username TEXT,
timestamp TEXT NOT NULL
)
''')
conn.commit()
conn.close()
def log_export_action(chat_id, chat_title, user_id, username):
"""Logs a successful export action to the database."""
conn = sqlite3.connect(DB_NAME)
cursor = conn.cursor()
timestamp = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
cursor.execute(
"INSERT INTO export_logs (chat_id, chat_title, requested_by_id, requested_by_username, timestamp) VALUES (?, ?, ?, ?, ?)",
(chat_id, chat_title, user_id, username, timestamp)
)
conn.commit()
conn.close()
# Hashtags: #SQLite #DatabaseDesign #Logging #DataPersistence
---
#Step 3: Implementing the Export Command and Permission CheckNow, we'll write the core function in
bot.py. This function will handle the /export command. The most crucial part is to check if the user who sent the command is the creator of the channel. This prevents any admin from exporting the data.❤4
#PDF #EPUB #TelegramBot #Python #SQLite #Project
Lesson: Building a PDF <> EPUB Telegram Converter Bot
This lesson walks you through creating a fully functional Telegram bot from scratch. The bot will accept PDF or EPUB files, convert them to the other format, and log each transaction in an SQLite database.
---
Part 1: Prerequisites & Setup
First, we need to install the necessary Python library for the Telegram Bot API. We will also rely on Calibre's command-line tools for conversion.
Important: You must install Calibre on the system where the bot will run and ensure its
#Setup #Prerequisites
---
Part 2: Database Initialization
We'll use SQLite to log every successful conversion. Create a file named
#Database #SQLite #Initialization
---
Part 3: The Main Bot Script - Imports & Basic Commands
Now, let's create our main bot file,
#TelegramBot #Python #Boilerplate
---
Part 4: The Core Conversion Logic
This function will be the heart of our bot. It uses the
Lesson: Building a PDF <> EPUB Telegram Converter Bot
This lesson walks you through creating a fully functional Telegram bot from scratch. The bot will accept PDF or EPUB files, convert them to the other format, and log each transaction in an SQLite database.
---
Part 1: Prerequisites & Setup
First, we need to install the necessary Python library for the Telegram Bot API. We will also rely on Calibre's command-line tools for conversion.
Important: You must install Calibre on the system where the bot will run and ensure its
ebook-convert tool is in your system's PATH.pip install python-telegram-bot==20.3#Setup #Prerequisites
---
Part 2: Database Initialization
We'll use SQLite to log every successful conversion. Create a file named
database_setup.py and run it once to create the database file and the table.# database_setup.py
import sqlite3
def setup_database():
conn = sqlite3.connect('conversions.db')
cursor = conn.cursor()
# Create table to store conversion logs
cursor.execute('''
CREATE TABLE IF NOT EXISTS conversions (
id INTEGER PRIMARY KEY AUTOINCREMENT,
user_id INTEGER NOT NULL,
original_filename TEXT NOT NULL,
converted_filename TEXT NOT NULL,
conversion_type TEXT NOT NULL,
timestamp DATETIME DEFAULT CURRENT_TIMESTAMP
)
''')
conn.commit()
conn.close()
print("Database setup complete. 'conversions.db' is ready.")
if __name__ == '__main__':
setup_database()
#Database #SQLite #Initialization
---
Part 3: The Main Bot Script - Imports & Basic Commands
Now, let's create our main bot file,
converter_bot.py. We'll start with imports and the initial /start and /help commands.# converter_bot.py
import logging
import os
import sqlite3
import subprocess
from telegram import Update
from telegram.ext import Application, CommandHandler, MessageHandler, filters, ContextTypes
# Enable logging
logging.basicConfig(format='%(asctime)s - %(name)s - %(levelname)s - %(message)s', level=logging.INFO)
# --- Bot Token ---
TELEGRAM_TOKEN = "YOUR_TELEGRAM_BOT_TOKEN"
# --- Command Handlers ---
async def start(update: Update, context: ContextTypes.DEFAULT_TYPE) -> None:
user = update.effective_user
await update.message.reply_html(
rf"Hi {user.mention_html()}! Send me a PDF or EPUB file to convert.",
)
async def help_command(update: Update, context: ContextTypes.DEFAULT_TYPE) -> None:
await update.message.reply_text("Simply send a .pdf file to get an .epub, or send an .epub file to get a .pdf. Note: Conversion quality depends on the source file's structure.")
#TelegramBot #Python #Boilerplate
---
Part 4: The Core Conversion Logic
This function will be the heart of our bot. It uses the
ebook-convert command-line tool (from Calibre) to perform the conversion. It's crucial that Calibre is installed correctly for this to work.