Show Menu
トピック×

Syntax for dimension expressions

ディメンション式は、単独で使用することはできませんが、ディメンションが指標式またはフィルター式の中で呼び出される場所ではどこでも使用できます。
  1. 下線を引いた語句は、式のテキストにそのまま入力する必要があります。
  2. ? の形式は、オプションのテキストを表します。
  3. * の形式は、0 回以上発生するテキストを表します。
  4. {A | B | C |...} の形式は、A または B または C... のように、所定のオプションのうちの 1 つのみから成るテキストを表します。
  5. [A,B) の形式は、A 以上 B 未満の数値の範囲を表します。
識別子
識別子は、名前付きディメンションを参照するものです。正しい識別子のルールについては、「 識別子の構文 」を参照してください。
例:Sessions[ Session_Number = “1” ] は、セッション番号が「1」のセッションの数です。セッション番号は、識別子によって参照される名前付きディメンションです。
(ディメンション)
(ディメンション) という式の結果は、ディメンションの式の結果と同じです。丸括弧は、式の中の演算の順序を指定します。
例:Sessions[ (Page) = “/home” ] は、「/home」というページを訪問するセッションの数です。
Dim by Level
ディメンション Dim と同じ要素を持つが、ディメンションレベルによって別のディメンションに関するディメンションを定義します。
具体的には、新しいディメンションの要素は、Dim の同じ要素と同じレベルの要素に関連付けられ、それらのレベルの要素に関連付けられた他のディメンションがあれば、その要素にも関連付けられます。
例:Sessions[ (Page by Visitor)=”/home” ] は、「/home」というページを訪問した訪問者のセッションの数です。
shift(Dim,Level,Group,N)
ディメンション Dim と同じ要素を持つディメンションを定義します。レベルの e 番目の要素と e+N 番目の要素がディメンショングループの同じ要素に関連する場合に、新しいディメンションでは、ディメンションレベルの e 番目の要素が、レベルの e+N 番目の要素に関連する Dim の要素と同じ要素に関連付けられます。
例:Page_Views[ shift(Page, Page_View, Session, 1)=”/home” ] は、同じセッションで表示された次のページが「/home」であるページビューの数です。
next(Dim,Level,Group,N)
shift(Dim,Level,Group,N) と同様ですが、ディメンションに空の値がある場合にスキップする点が異なります。
segment(Level {,String->Filter}*)
フィルターのリストに基づいてレベルの要素を分類するディメンションを定義します。新しいディメンションの要素は、引数として与えた文字列 String です。Level の各要素は、セグメントディメンションの要素のうち、そのフィルターが Level の要素を通す最初の要素に関連付けられます。これはセグメントのビジュアライゼーションと同様です。
例:segment(Visitor, "One-Time Visitors" -> Visitor_Sessions = 1, "Very Loyal Visitors" -> Visitor_Sessions > 10, "Everyone Else" -> True) は、訪問者を 3 つのグループに分類するディメンションを作成します。One-Time Visitors はセッションが 1 回だけの訪問者で、Very Loyal Visitors はセッションが 10 回を超える訪問者です。それ以外のすべての訪問者の値は Everyone Else になります。
bucket(Level, Metric, Count, Format {, Start {, Size}? }?)
要素が数値範囲(固定サイズ、例えば、[0-9]、[10-19] など)のディメンションを定義します。Level の要素は、そのレベルの要素の Metric の値を範囲に含むバケットディメンションの要素に関連付けられます。Format は、指標の要素の書式設定に使用する printf 書式の文字列です。
例:Page_Duration_Minutes が、各ページに滞在した時間(分)を表すページビューレベルのディメンションである場合、bucket(Session, sum(Page_Duration_Minutes, Page_View), 100, "%0.0f minutes", 0, 5) は、各セッションに使用した時間(分)を表すセッションレベルのディメンションで、その要素は 5 分間隔の {[0-5), [5-10),...,[495-500)} です。
Start は、最初の間隔の開始値(デフォルト:0)であり、Size は間隔のサイズ(デフォルト:1)です。
prefix(Level {,ElementName->(Prefix{,Prefix}* )}* )
指定した文字列 ElementName を要素とし、対応する文字列 Prefix のセットにそれらの要素が関連付けられているディメンションを定義します。Level の要素は、プレフィックスディメンションの要素に関連付けられますが、その際、レベルの要素の名前と一致する最も長いプレフィックスに関連付けられたプレフィックスディメンションの要素が選択されます。特殊文字「$」で終わるプレフィックスの場合は、完全に一致する必要があります。
例えば、prefix(URI, "Products" -> ("/products/"), "Services" -> ("/services/", "/products/service/"), "Warranties" -> ("/products/warranty.html$", "/services/warranty.html$", "Everything Else" -> ("/"))) は、URI を 4 つのカテゴリーに分類するディメンションを作成します。様々なページに対する効果は次のとおりです。
/products/warranty.html は、/products/warranty.html$ というプレフィックスと完全に一致するので、Warranty に分類されます。
/products/cars/specialcar.html は、/products/ というプレフィックスと一致し、これ以上長いプレフィックスとは一致しないので、Products に分類されます。
/products/service/something.html は、/products/ プレフィックスよりも長い /products/service/ というプレフィックスと一致するので、Services に分類されます。
/companyinfo/aboutus.html は、「/」というプレフィックスにのみ一致するので、「Everything Else」カテゴリーに分類されます。
latency(Level, Clip, Dim, Filter, MaxBefore, MaxAfter, FormatString)
cartesian_product(Separator {,Dim}*)
指定したディメンションの要素のすべての組み合わせ(「デカルト積」)を要素とするディメンションを定義します。各要素の名前は、入力ディメンションの中の対応する要素を、指定した Separator 文字列で区切って連結した名前になります。
例えば、ディメンション D1 の要素が {"a", "b"} で、ディメンション D2 の要素が {"x", "y"} の場合、デカルト積 cartesian product("-", D1, D2) の要素は {"a-x", "a-y", "b-x", "b-y"} になります。
内部的には、入力ディメンションはそれぞれ、要素の数が 2 のべき乗(要素の数以上で最も近い数)であるかのように扱われます。このため、デカルト積にはダミーの要素がいくつか存在することになります。Data Workbench APIを使用する場合、出力形式に応じて、これらの要素は省略される場合や、「#nnn」(nnnは要素の序数)と表示される場合があります(クライアントでは無視する必要があります)。
例えば、上記の例で D2 に 3 つの要素 {"x", "y", "z"} がある場合、要素は 4 つあるもとのして扱われ、デカルト積の要素は {"a-x", "a-y", "a-z", "#3", "b-x", "b-y", "b-z", "#7"} となります。
ディメンションを指定しない場合、1 つの要素「#0」を持つディメンションとなり、None ディメンションと等しくなります。
nearest_countable(Dim)
既に存在するディメンションを参照します。スキーマ内の Dim の親ディメンションのうち最も近い可算ディメンションです。例えば、nearest countable(URI) は Page_View と同一です。
normalized(Dim,Count)
最大 Count 個の要素で、非正規ディメンション Dim から正規化されたディメンションを定義します。
last_n(Dim, TimeMetric, FormatString, Count, Offset, TrimToData {, WeekStart}?)
日、週、年など、期間を表す要素から成るディメンション Dim に対し、Dim の要素のサブセットから成るディメンションを定義します。
サブセットは、定数の指標 TimeMetric の値で指定した時間に近い範囲です。ここで、TimeMetric の値は、1970 年 1 月 1 日午前 0 時(UTC)からの時間(秒)と解釈されます。範囲には Count 個の要素が含まれ、その最後の要素は、指定した Dim の要素の Offset 個後の要素となります。この要素の名前は、指定した文字列 FormatString で指標の値を書式設定した結果です。FormatString では、標準の C ライブラリ関数 strftime と同じ % エスケープを使用します。
trimToData が true の場合、結果のディメンションの先頭にある要素(Dim の先頭より前の要素)は削除されます。false の場合、Count で指定した数の要素が必ず存在します。結果のディメンションの最後には、実際には Dim にない要素が常に存在する可能性があります。
オプションの WeekStart を指定する場合、{ "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" } のいずれかにする必要があります。これにより、その曜日になる最も近い日まで TimeMetric が過去に移動されます。
例:Week の要素が { "10/03/10", "10/10/10", ..., "12/12/10" } で、内蔵の As Of 指標の値が 1292348109(2010 年 12 月 14 日の中頃)の場合、last n(Week, As_Of, "%m/%d/%y", 4, 0, false, "Sun") は、{ "12/12/10", "12/19/10", "12/23/10", "12/30/10" } という要素を持つディメンションを定義します。
例 2:Week ディメンションの要素が {"12/19/10", "12/26/10", ..., "01/30/11"} だけで、As Of 指標が上記のとおりの場合、last n(Week, As_Of, "%m/%d/%y", 4, 0, true, "Sun") は、{"12/19/10", "12/23/10", "12/30/10"} という要素を持つディメンションになります。
days_of_previous_months(Dim, TimeMetric, FormatString, nMonths, includeThisMonth, TrimToData)
日を表す要素から成るディメンション Dim に対し、Dim の要素のサブセットから成るディメンションを定義します。サブセットは、定数の指標 TimeMetric の値で指定した時間に近い範囲です。ここで、TimeMetric の値は、1970 年 1 月 1 日午前 0 時(UTC)からの時間(秒)と解釈されます。範囲には、指定した時間より前の nMonths か月の各日に対応する要素が含まれます。includeThisMonth が true の場合、指定した時間を含む月の各日も範囲に含まれます。
FormatString は、標準の C ライブラリ関数 strftime のように、「%」エスケープを使用して Dim の要素の書式を指定します。
trimToData が true の場合、結果のディメンションの先頭にある要素(Dim の先頭より前の要素)は削除されます。false の場合、Count で指定した数の要素が必ず存在します。結果のディメンションの最後には、実際には Dim にない要素が常に存在する可能性があります。
例:Day の要素が { "01/01/10", "01/02/10", ..., "12/31/10" } で、内蔵の As Of 指標の値が 1292348109(2010 年 12 月 14 日の中頃)の場合、previous months(Day, As_Of, "%m/%d/%y", 2, false, false) の要素は { "10/01/10", "10/02/10", ..., "11/30/10" } です。
days_of_current_month(Dim, TimeMetric, FormatString, allMonth, trimToData)
days_of_previous_months と同様ですが、要素が、TimeMetric で指定した時間と同じ月の日にのみ対応する点が異なります。allMonth が true の場合、該当する月の各日に対応する要素があります。true でない場合は、該当する月の初めから、指定した時間を含む日までの日付だけがディメンションの部分になります。
days_of_future_months(Dim, TimeMetric, FormatString, nMonths, includeThisMonth, TrimToData)
days of previous months と同様ですが、要素が、TimeMetric で指定した時間を含む月の前ではなく、後の月の日に対応する点が異なります。
hours_of_day(Dim, Metric, TimeFormatString, nDaysForward, TrimData)
時間を表す要素から成るディメンション Dim に対し、Dim の要素のサブセットから成るディメンションを定義します。サブセットは、定数の指標 TimeMetric の値で指定した時間に近い範囲です。ここで、TimeMetric の値は、1970 年 1 月 1 日午前 0 時(UTC)からの時間(秒)と解釈されます。範囲には、TimeMetric で指定した時間を含む日の nDaysForward 日後の日の各時間に対応する要素が含まれます。
FormatString は、標準の C ライブラリ関数 strftime のように、「%」エスケープを使用して Dim の要素の書式を指定します。書式の文字列は、必ず、渡された時間の日の初めにあたる午前 0 時を表す文字列を出力する必要があります。
trimToData が true の場合、結果のディメンションの先頭にある要素(Dim の先頭より前の要素)は削除されます。false の場合、Count で指定した数の要素が必ず存在します。結果のディメンションの最後には、実際には Dim にない要素が常に存在する可能性があります。
例:Hour の要素が { "01/01/10 00:00", "01/01/10 01:00", ..., "12/31/10 23:00" } で、内蔵の As Of 指標の値が 1292348109(2010 年 12 月 14 日の中頃)の場合、hours of day(Hour, As_Of, "%x 00:00", 0, false) の要素は { "12/12/10 00:00", "12/12/10 01:00", ..., "12/12/10 23:00" } です。