すべてのプロダクト
Search
ドキュメントセンター

ApsaraVideo VOD:Dictionary 関数

最終更新日:Mar 12, 2025

このトピックでは、ディクショナリ関数の構文、説明、パラメーター、および応答パラメーターについて説明します。 このトピックでは、これらの関数の例も示します。

set

dパラメーターで指定したディクショナリにキーと値のペアを設定します。 この関数の詳細を次の表に示します。

項目

説明

構文

セット (d、k、v)

パラメーター

  • d: 辞書の名前。

  • k: キー。 データ型: 任意の型。

  • v: 値。 データ型: 任意の型。

  • 例1

    outer_keys=['e66fd4aa-f281-472f-b919-fc7e747****', '66fee78d-1887-42ec-9119-a9b50b7f****']
    say(concat('keys[1]=', get(outer_keys, 1)))
    say(concat('keys[2]=', get(outer_keys, 2)))
    
    inner_keys=[]
    set(inner_keys, 'dev', '243390eb-00b7-4551-a6b8-021bb34d****')
    set(inner_keys, 'zeus', '4747d33b-12b0-45e6-ac10-a8e191d6****')
    
    def echo_each(k, v, u) {
        s = concat('keys[', k, ']=', v)
        say(s)
    }
    foreach(inner_keys, echo_each, [])                                                                                                                                             
  • 例2

    d_inner = []
    set(d_inner, 'name', 'inner dsl')
    
    d_outer = []
    set(d_outer, 'dictA', d_inner)
    
    v = get(d_outer, 'dictA')
    if v {
        v = get(v, 'name')
        if v {
            add_rsp_header('X-DSL-NESTED-DICT', v)
        }
    }

レスポンスパラメーター

trueの値を返します。 例1および例2の応答パラメータ:

  • 例1

    keys[1]=e66fd4aa-f281-472f-b919-fc7e7474****
    keys[2]=66fee78d-1887-42ec-9119-a9b50b7f****
    keys[dev]=243390eb-00b7-4551-a6b8-021bb34d****
    keys[zeus]=4747d33b-12b0-45e6-ac10-a8e191d6****
  • 例2: 応答ヘッダが追加される。

    X-DSL-NESTED-DICT: inner dsl

get

キー (k) に対応する値 (v) を辞書 (d) から取得します。 この関数の詳細を次の表に示します。

項目

説明

構文

get(d, k)

パラメーター

  • d: 辞書の名前。

  • k: キー。 データ型: 任意の型。

outer_keys=['e66fd4aa-f281-472f-b919-fc7e747****', '66fee78d-1887-42ec-9119-a9b50b7f****']
say(concat('keys[1]=', get(outer_keys, 1)))
say(concat('keys[2]=', get(outer_keys, 2)))

inner_keys=[]
set(inner_keys, 'dev', '243390eb-00b7-4551-a6b8-021bb34d****')
set(inner_keys, 'zeus', '4747d33b-12b0-45e6-ac10-a8e191d6****')

def echo_each(k, v, u) {
    s = concat('keys[', k, ']=', v)
    say(s)
}
foreach(inner_keys, echo_each, [])                                                                                                                                             

レスポンスパラメーター

関数が成功すると、指定されたキーに対応する値が返されます。 それ以外の場合、falseの値が返されます。 この例の応答パラメーター:

keys[1]=e66fd4aa-f281-472f-b919-fc7e7474****
keys[2]=66fee78d-1887-42ec-9119-a9b50b7f****
keys[dev]=243390eb-00b7-4551-a6b8-021bb34d****
keys[zeus]=4747d33b-12b0-45e6-ac10-a8e191d6****

foreach

この機能についての詳細:

  • ディクショナリ (d) 内の要素をトラバースし、各要素のコールバック関数 (f) を呼び出します。

  • f(key, value, user_data) の構文でfパラメーターを指定します。

  • f() 関数がfalseを返すと、foreach() ループが終了します。

次の表に、この関数の詳細を示します。

項目

説明

構文

foreach(d, f, user_data)

パラメーター

  • d: 辞書の名前。

  • f: コールバック関数。

  • user_data: 送信するユーザーデータ。 データ型: dictionary。

  • 例1

    outer_keys=['e66fd4aa-f281-472f-b919-fc7e747****', '66fee78d-1887-42ec-9119-a9b50b7f****']
    say(concat('keys[1]=', get(outer_keys, 1)))
    say(concat('keys[2]=', get(outer_keys, 2)))
    
    inner_keys=[]
    set(inner_keys, 'dev', '243390eb-00b7-4551-a6b8-021bb34d****')
    set(inner_keys, 'zeus', '4747d33b-12b0-45e6-ac10-a8e191d6****')
    
    def echo_each(k, v, u) {
        s = concat('keys[', k, ']=', v)
        say(s)
    }
    foreach(inner_keys, echo_each, [])                                                                                                                                             
  • 例 2

    最初の2つのM3U8スライスを印刷し、foreachループを終了します。

    def echo_each(k, v, u) {
        say(v)
    
        if match_re(v, '.*ts') {
            ts_cnt = get(u, 'ts_cnt')
            ts_cnt = add(ts_cnt, 1)
            set(u, 'ts_cnt', ts_cnt)
    
            if ge(ts_cnt, 2) {
                return false
            }
        }
    }
    
    m3u8 = ''
    m3u8 = concat(m3u8, '#EXTM3U8', '\n')
    m3u8 = concat(m3u8, '#EXT-X-MEDIA-SEQUENCE:140651513\n')
    m3u8 = concat(m3u8, '#EXT-X-TARGETDURATION:10\n')
    m3u8 = concat(m3u8, '#EXTINF:8,\n')
    m3u8 = concat(m3u8, 'http://***.cn/cache/289_/seg0/index140651514_1406****.ts\n')
    m3u8 = concat(m3u8, '#EXTINF:9,\n')
    m3u8 = concat(m3u8, 'http://***.cn/cache/289_/seg0/index140651514_1406****.ts\n')
    m3u8 = concat(m3u8, '#EXTINF:10,\n')
    m3u8 = concat(m3u8, 'http://***.cn/cache/289_/seg0/index140651514_1406****.ts\n')
    
    lines = split(m3u8, '\n')
    u = []
    set(u, 'ts_cnt', 0)
    foreach(lines, echo_each, u)

レスポンスパラメーター

trueの値を返します。 例1および例2の応答パラメータ:

  • 例1

    keys[1]=e66fd4aa-f281-472f-b919-fc7e7474****
    keys[2]=66fee78d-1887-42ec-9119-a9b50b7f****
    keys[dev]=243390eb-00b7-4551-a6b8-021bb34d****
    keys[zeus]=4747d33b-12b0-45e6-ac10-a8e191d6****
  • 例2

    #EXTM3U8
    #EXT-X-MEDIA-SEQUENCE:140651513
    #EXT-X-TARGETDURATION:10
    #EXTINF:8,
    http://***.cn/cache/289_/seg0/index140651514_1406****.ts
    #EXTINF:9,
    http://***.cn/cache/289_/seg0/index140651514_1406****.ts

del

辞書からキーと値のペアを削除します (d) 。 次の表に、この関数の詳細を示します。

項目

説明

構文

del(d, k)

パラメーター

  • d: 辞書の名前。

  • k: キー。 データ型: 任意の型。

var_a = []
set(var_a, 'note_a', 'note a info')
if get(var_a, 'note_a') {
    add_rsp_header('X-RESPOND-OUTPUT', 'found var_a key', true)
} else {
    add_rsp_header('X-RESPOND-OUTPUT', 'del var_a key', true)
}
del(var_a, 'note_a')
if get(var_a, 'note_a') {
    add_rsp_header('X-RESPOND-OUTPUT', 'found var_a key', true)
} else {
    add_rsp_header('X-RESPOND-OUTPUT', 'del var_a key', true)
}

レスポンスパラメーター

trueの値を返します。 この例のレスポンスパラメーター:

X-RESPOND-OUTPUT: found var_a key
X-RESPOND-OUTPUT: del var_a key