Building a Multi-Market Breakout Stock Screener in Python
📈 Introduction
In the fast-paced world of stock trading, identifying breakouts—moments when a stock’s price pushes above resistance with strong volume—can lead to powerful opportunities. To automate this process, we developed a multi-market breakout stock screener using Python.
This tool scans across markets like the NYSE, Nikkei 50, and Vietnam 50, analyzing price and volume data to pinpoint potential breakout candidates — and it even generates candlestick charts automatically.
🧠 System Overview
The project consists of three modules that work together seamlessly:
| File | Purpose |
|---|---|
test10.py |
The heart of the system — fetches data and applies breakout screening logic. |
breakout.py |
Provides a clean command-line interface (CLI) for running the screener. |
ui_breakout.py |
A graphical user interface (GUI) built with Tkinter for intuitive use. |
Architecture
flowchart TD
A["ui_breakout.py (GUI Interface)"] --> B["breakout.py (CLI Wrapper)"]
B --> C["test10.py (Core Screener)"]
C --> D["Yahoo Finance API"]
C --> E["Chart Generator (Plotly HTML/PNG)"]
⚙️ How It Works
1. Data Collection
The screener fetches three months of daily stock data from Yahoo Finance for top stocks in each market.
Tickers are automatically loaded (e.g., top 50 by market cap for NYSE, Nikkei, and Vietnam).
2. Screening Logic
The script applies a set of breakout filters:
- Recent High: The close price must exceed the previous
lookbackperiod high. - Volume Surge: The trading volume must exceed the average by a configurable multiple (e.g., 1.5×).
- Liquidity Filter: Ensures sufficient dollar volume to avoid illiquid stocks.
- Weekly Confirmation (optional): Confirms breakouts on weekly timeframes.
Example core logic:
if is_breakout(df_t,
lookback=lookback,
volume_mult=volume_mult,
min_margin=min_margin,
min_close_pct=min_close_pct,
weekly_confirm=weekly_confirm,
weekly_lookback=weekly_lookback):
results.append(t)
The program can retry downloads automatically if rate-limited and runs in batches for efficiency.
🌏 Multi-Market Scanning
You can screen multiple markets simultaneously:
- 🇺🇸 NYSE
- 🇯🇵 Nikkei 50
- 🇻🇳 Vietnam 50
- 🇨🇳 SSE 50
- 🇭🇰 HSI 50
- 🇪🇺 Euronext
- 🇺🇸 S&P 50 / 500
Each market uses a tailored ticker list and outputs separate breakout results and charts.
📊 Chart Generation
After detecting breakout candidates, the system can automatically create candlestick charts using Plotly.
Each chart shows:
- Price and volume data
- Recent highs and breakout zones
- Clear visual confirmation of the breakout setup
Example command:
python breakout.py --markets nyse,nikkei50 --charts --chart-format html
Charts are saved under:
charts/<market>/<ticker>.html
🖥️ Graphical User Interface (GUI)
For users who prefer a visual interface, the Tkinter-based GUI (ui_breakout.py) provides:
✅ Market selection checkboxes
✅ Adjustable filters and thresholds
✅ Real-time log output
✅ Run and cancel buttons
✅ Automatic chart previews

The GUI executes the same backend logic but allows easy exploration without command-line input.
🔧 Example Usage
python breakout.py \
--markets sp500,nyse \
--lookback 20 \
--volume-mult 1.8 \
--charts \
--weekly-confirm
Sample output:
=========> NYSE breakouts: ['AAPL', 'NVDA', 'LMT']
=========> Nikkei50 breakouts: ['SONY', 'TOYOTA']
Saved 12 breakout chart(s) under 'charts/nyse/*.html'
💡 Use Cases
- Swing traders can identify early momentum setups.
- Quant developers can integrate this logic into automated pipelines.
- Analysts and educators can visualize live breakouts in class or reports.
🚀 Future Enhancements
- Add RSI / moving average filters
- Integrate Telegram or Line alerts
- Deploy as a web dashboard with FastAPI
- Include auto-updating market data and backtesting
🧭 Conclusion
This breakout screener demonstrates how Python + yfinance + Plotly can create a professional-grade stock analysis tool.
Whether you prefer CLI or GUI, it helps traders spot breakout opportunities early and visually confirm them before the crowd reacts.
Get in Touch with us
Related Posts
- ERP项目为何失败(以及如何让你的项目成功)
- Why ERP Projects Fail (And How to Make Yours Succeed)
- Payment API幂等性设计:用Stripe、支付宝、微信支付和2C2P防止重复扣款
- Idempotency in Payment APIs: Prevent Double Charges with Stripe, Omise, and 2C2P
- Agentic AI in SOC Workflows: Beyond Playbooks, Into Autonomous Defense (2026 Guide)
- 从零构建SOC:Wazuh + IRIS-web 真实项目实战报告
- Building a SOC from Scratch: A Real-World Wazuh + IRIS-web Field Report
- 中国品牌出海东南亚:支付、物流与ERP全链路集成技术方案
- 再生资源工厂管理系统:中国回收企业如何在不知不觉中蒙受损失
- 如何将电商平台与ERP系统打通:实战指南(2026年版)
- AI 编程助手到底在用哪些工具?(Claude Code、Codex CLI、Aider 深度解析)
- 使用 Wazuh + 开源工具构建轻量级 SOC:实战指南(2026年版)
- 能源管理软件的ROI:企业电费真的能降低15–40%吗?
- The ROI of Smart Energy: How Software Is Cutting Costs for Forward-Thinking Businesses
- How to Build a Lightweight SOC Using Wazuh + Open Source
- How to Connect Your Ecommerce Store to Your ERP: A Practical Guide (2026)
- What Tools Do AI Coding Assistants Actually Use? (Claude Code, Codex CLI, Aider)
- How to Improve Fuel Economy: The Physics of High Load, Low RPM Driving
- 泰国榴莲仓储管理系统 — 批次追溯、冷链监控、GMP合规、ERP对接一体化
- Durian & Fruit Depot Management Software — WMS, ERP Integration & Export Automation













