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

Проєктуємо та розробляємо блокчейн-рішення повного циклу: від архітектури смарт-контрактів до запуску DeFi-протоколів, NFT-маркетплейсів та криптобірж. Аудит безпеки, токеноміка, інтеграція з наявною інфраструктурою.
Показано 1 з 1Усі 1306 послуг
Розробка індикаторів на Pine Script (TradingView)
Середній
від 1 дня до 3 днів
Часті запитання

Напрямки блокчейн-розробки

Етапи блокчейн-розробки

Останні роботи

  • image_website-b2b-advance_0.webp
    Розробка сайту компанії B2B ADVANCE
    1288
  • image_web-applications_feedme_466_0.webp
    Розробка веб-додатків для компанії FEEDME
    1198
  • image_websites_belfingroup_462_0.webp
    Розробка веб-сайту для компанії БЕЛФІНГРУП
    902
  • image_ecommerce_furnoro_435_0.webp
    Розробка інтернет магазину для компанії FURNORO
    1122
  • image_logo-advance_0.webp
    Розробка логотипу компанії B2B Advance
    589
  • image_crm_enviok_479_0.webp
    Розробка веб-додатків для компанії Enviok
    859

Розробка індикаторів на 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 — це потужний маркетинговий інструмент і джерело довіри до автора.