Разработка индикаторов на Pine Script (TradingView)
Pine Script — собственный язык программирования TradingView для создания индикаторов и стратегий. Работает прямо в браузере, имеет доступ к полной истории котировок, и позволяет публиковать работы для миллионной аудитории TradingView. Разберём ключевые паттерны разработки на Pine Script v5.
Основы 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 выполняется на каждом баре слева направо. Переменные — это не скалярные значения, а серии (series). close — это не текущая цена, а массив всех закрытий, где close[0] = текущий бар, close[1] = предыдущий.
Типы данных и серии
// Числовые операции со сдвигом
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 для кастомных серий - Нет реального order management (стратегии — только backtesting)
- Нет persistent storage между сессиями
Лучшие практики:
- Используй
varдля переменных, которые нужно сохранять между барами -
barstate.islastдля расчётов только на последнем баре (таблицы, labels) -
barstate.isconfirmedдля избежания repainting на незакрытой свече - Всегда добавляй
naпроверки:if not na(value) then...
Качественный Pine Script индикатор с 10,000+ лайков на TradingView — это мощный маркетинговый инструмент и источник доверия к автору.







