Skip to content

控制結構

Pine Script 中所有控制結構都是運算式 — 它們會產生一個值。在執行的分支或迭代中最後計算的運算式就是返回值。這意味着 ifforwhileswitch 都可以出現在賦值的右側。

if / else if / else

pine
if close > open
    label.new(bar_index, high, "Bullish")
else if close < open
    label.new(bar_index, low, "Bearish")
else
    label.new(bar_index, close, "Doji")

if 返回值

每個分支的最後一個運算式就是結果。所有分支必須返回相同類型:

pine
x = if close > open
    close
else
    open

plot(x)

使用 else if

pine
x = if open > close
    5
else if high > low
    close
else
    open

當省略 else 塊時,條件為假時結果為 na(對於 bool/string 則為 false / ""):

pine
x = if close > open
    close
// 當 close <= open 時 x 為 na

if 返回元組

每個分支必須返回相同結構的元組:

pine
[v1, v2] = if close > open
    [high, close]
else
    [close, low]

for 迴圈

計數形式

pine
sum = 0.0
for i = 0 to 9
    sum += close[i]
averageClose = sum / 10

指定步長:

pine
for i = 0 to 20 by 2
    // i = 0, 2, 4, 6, ..., 20

反向迴圈(負步長):

pine
for i = 10 to 0 by -1
    array.push(arr, i)
    // i = 10, 9, 8, ..., 0

集合迭代(for...in

遍歷陣列,僅取得值,或同時取得索引和值:

pine
var prices = array.from(100.0, 200.0, 300.0)

// 僅取得值
for value in prices
    log.info(str.tostring(value))

// 索引和值(解構)
for [index, value] in prices
    log.info(str.tostring(index) + ": " + str.tostring(value))

for 返回值

for 迴圈返回最後一次迭代中最後計算的運算式。如果沒有迭代執行,則返回 na

pine
// 統計 OHLC 值中有多少大於 SMA
array<float> ohlcValues = array.from(open, high, low, close)
qtyGreaterThan(value, array) =>
    int result = 0
    for currentElement in array
        if currentElement > value
            result += 1
        result
plot(qtyGreaterThan(ta.sma(close, 20), ohlcValues))

while 迴圈

pine
i = 0
sum = 0.0
while i < 10
    sum += close[i]
    i += 1

while 返回值

for 類似,while 迴圈返回最後一次迭代中最後計算的運算式:

pine
int i = 0
int result = while i < 10
    i += 1
    i * 2
// result 為 20(最後一次迭代:i = 10, 10 * 2 = 20)

breakcontinue

  • break 立即退出迴圈。迴圈返回 break 之前最後計算的運算式的值。
  • continue 跳過當前迭代的其餘部分,繼續下一次迭代。
pine
for i = 0 to 99
    if close[i] < 0
        break          // 退出迴圈
    if na(close[i])
        continue       // 跳過此迭代
    // 處理 close[i]

breakcontinue 與迴圈返回值配合使用:

pine
string tempString = ""
string finalText = for number in randomArray
    if number == 8
        break                  // 退出迴圈;返回最後計算的運算式
    else if number % 2 == 0
        continue               // 跳過偶數
    tempString := tempString + str.tostring(number) + ", "
// finalText 儲存迴圈終止後的返回值

switch

帶值匹配

匹配特定值:

pine
dayName = switch dayofweek
    dayofweek.monday    => "Mon"
    dayofweek.tuesday   => "Tue"
    dayofweek.wednesday => "Wed"
    dayofweek.thursday  => "Thu"
    dayofweek.friday    => "Fri"
    => "Weekend"
pine
string i_maType = input.string("EMA", "MA type", options = ["EMA", "SMA", "RMA", "WMA"])

float ma = switch i_maType
    "EMA" => ta.ema(close, 10)
    "SMA" => ta.sma(close, 10)
    "RMA" => ta.rma(close, 10)
    => ta.wma(close, 10)

plot(ma)

無值匹配(基於條件)

當沒有提供匹配運算式時,每個分支使用布林條件。第一個匹配的分支會執行:

pine
direction = switch
    close > open => "up"
    close < open => "down"
    => "flat"  // 預設值

switch 返回元組

pine
[v1, v2] = switch
    close > open => [high, close]
    =>              [close, low]

switch 分支使用 => 分隔條件和主體。預設分支在 => 之前沒有條件。

下一步

基於 MIT 許可證發佈。