Разработка индикаторов на Pine Script (TradingView)

Проектируем и разрабатываем блокчейн-решения полного цикла: от архитектуры смарт-контрактов до запуска DeFi-протоколов, NFT-маркетплейсов и криптобирж. Аудит безопасности, токеномика, интеграция с существующей инфраструктурой.
Показано 1 из 1 услугВсе 1306 услуг
Разработка индикаторов на Pine Script (TradingView)
Средняя
от 1 рабочего дня до 3 рабочих дней
Часто задаваемые вопросы
Направления блокчейн-разработки
Этапы блокчейн-разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1221
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1163
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    855
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1062
  • image_logo-advance_0.png
    Разработка логотипа компании B2B Advance
    561
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    828

Разработка индикаторов на 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 — это мощный маркетинговый инструмент и источник доверия к автору.