Розробка індикаторів на Pine Script (TradingView)
Pine Script — власна мова програмування TradingView для створення індикаторів та стратегій прямо в браузері. Виглядає просто, але написати стратегію, яка не дає false signals на історичних даних і реально торгує прибутково — нетривіальна задача.
Основи Pine Script v5
Структура скрипта
//@version=5
indicator("My Indicator", shorttitle="MI", overlay=true, max_bars_back=500)
// Параметри (настраюються користувачем)
length = input.int(14, "Period", minval=1, maxval=200)
source = input.source(close, "Source")
show_signals = input.bool(true, "Show Signals")
// Вычисления
ema_line = ta.ema(source, length)
// Візуалізація
plot(ema_line, "EMA", color=color.blue, linewidth=2)
Ключове відхилення від звичайного програмування: Pine Script виконується на кожному барі зліва направо. Змінні — це не скалярні значення, а серії. close — це не поточна ціна, а масив всіх закриттів, де close[0] = поточний бар, close[1] = попередній.
Типи даних та серії
// Числові операції з offset
prev_close = close[1] // попередній бар
two_bars_ago = close[2]
// Умови на серіях
is_bullish = close > open // true/false для кожного бара
is_green_candle = close >= open
// Операції з серіями
rising = close > close[1] and close[1] > close[2] // три зростаючих бара поспіль
Технічні індикатори
Продвинутий RSI з дивергенцією
//@version=5
indicator("RSI with Divergence", overlay=false)
rsi_length = input.int(14, "RSI Length")
rsi_overbought = input.int(70, "Overbought")
rsi_oversold = input.int(30, "Oversold")
div_lookback = input.int(15, "Divergence Lookback")
rsi = ta.rsi(close, rsi_length)
// Бичяча дивергенція: ціна робить новий низ, RSI — ні
price_lower_low = low < ta.lowest(low, div_lookback)[1]
rsi_higher_low = rsi > ta.lowest(rsi, div_lookback)[1]
bullish_div = price_lower_low and rsi_higher_low and rsi < rsi_oversold + 10
// Медвежья дивергенція
price_higher_high = high > ta.highest(high, div_lookback)[1]
rsi_lower_high = rsi < ta.highest(rsi, div_lookback)[1]
bearish_div = price_higher_high and rsi_lower_high and rsi > rsi_overbought - 10
// Візуалізація
hline(rsi_overbought, "Overbought", color.new(color.red, 50))
hline(rsi_oversold, "Oversold", color.new(color.green, 50))
hline(50, "Midline", color.gray, linestyle=hline.style_dotted)
rsi_color = rsi >= rsi_overbought ? color.red : rsi <= rsi_oversold ? color.green : color.blue
plot(rsi, "RSI", color=rsi_color, linewidth=2)
// Маркери дивергенції
plotshape(bullish_div, "Bullish Div", shape.triangleup, location.bottom,
color.new(color.green, 0), size=size.small)
plotshape(bearish_div, "Bearish Div", shape.triangledown, location.top,
color.new(color.red, 0), size=size.small)
Стратегія з backtesting
//@version=5
strategy("EMA Cross Strategy", overlay=true, initial_capital=10000,
commission_type=strategy.commission.percent, commission_value=0.1)
fast_ema = input.int(9, "Fast EMA")
slow_ema = input.int(21, "Slow EMA")
ema_fast = ta.ema(close, fast_ema)
ema_slow = ta.ema(close, slow_ema)
// Сигнали
long_signal = ta.crossover(ema_fast, ema_slow)
short_signal = ta.crossunder(ema_fast, ema_slow)
// Входи/виходи
if long_signal
strategy.entry("Long", strategy.long)
if short_signal
strategy.close("Long")
// Візуалізація
plot(ema_fast, "Fast EMA", color.blue)
plot(ema_slow, "Slow EMA", color.orange)
bgcolor(long_signal ? color.new(color.green, 90) : na)
Після написання стратегії — вкладка "Strategy Tester" в TradingView показує всі метрики backtesting: Net Profit, Profit Factor, Max Drawdown, Win Rate.
Робота з таблицями та labels
// Таблиця з метриками у кутку графіка
var table metrics_table = table.new(position.top_right, 2, 5,
bgcolor=color.new(color.black, 70), border_width=1)
if barstate.islast // малюємо тільки на останньому барі
table.cell(metrics_table, 0, 0, "RSI", text_color=color.gray)
table.cell(metrics_table, 1, 0, str.tostring(math.round(rsi, 2)),
text_color=rsi > 70 ? color.red : rsi < 30 ? color.green : color.white)
// Labels на ціновому графіку
if long_signal
label.new(bar_index, low, "BUY\n" + str.tostring(close),
color=color.green, textcolor=color.white,
style=label.style_label_up, size=size.small)
Функції та бібліотеки
Pine Script v5 підтримує користувацькі функції та import:
// Кастомна функція
f_supertrend(factor, atr_period) =>
atr = ta.atr(atr_period)
upperband = hl2 + factor * atr
lowerband = hl2 - factor * atr
supertrend = 0.0
direction = 0
supertrend := close > nz(supertrend[1]) ? math.max(lowerband, nz(supertrend[1])) :
math.min(upperband, nz(supertrend[1]))
direction := close > supertrend ? 1 : -1
[supertrend, direction]
[st_line, st_dir] = f_supertrend(3.0, 10)
plot(st_line, "Supertrend", st_dir == 1 ? color.green : color.red, linewidth=2)
// Import бібліотеки (v5)
import TradingView/ta/2 as tvta
Обмеження та найкращі практики
Обмеження Pine Script:
- Немає доступу до зовнішніх API (тільки TradingView дані)
- Максимум
max_bars_back= 500 для кастомних серій - Немає реального управління ордерами (стратегії — тільки backtesting)
- Немає persistent storage між сесіями
Найкращі практики:
- Використовуйте
varдля змінних, які потрібно зберігати між барами -
barstate.islastдля розрахунків тільки на останньому барі (таблиці, labels) -
barstate.isconfirmedдля避免 repainting на незакритій свічці - Завжди додавайте
naперевірки:if not na(value) then...
Якісний Pine Script індикатор з 10,000+ лайками на TradingView — це потужний маркетинговий інструмент і джерело довіри до автора.







