otp.Source.where_clause#
- Source.where_clause(condition, discard_on_match=False, stop_on_first_mismatch=False)#
- Split source in two branches depending on - condition: one branch with ticks that meet the condition and the other branch with ticks that don’t meet the condition.- Original source object is not modified. - Parameters
- condition ( - Operation,- eval()) – Condition expression to filter ticks or object evaluating another query. In the latter case another query should have only one tick as a result with only one field.
- discard_on_match (bool) – - Inverts the - condition.- Ticks that don’t meet the condition will be returned in the first branch, and ticks that meet the condition will be returned in the second branch. 
- stop_on_first_mismatch (bool) – - If set, no ticks will be propagated in the first branch starting with the first tick that does not meet the - condition.- Other branch will contain all ticks starting with the first mismatch, even if they don’t meet the condition. 
 
- Return type
- Tuple[onetick.py.core.source.Source, onetick.py.core.source.Source] 
 - Examples - Filtering based on expression: - >>> data = otp.Ticks(X=[1, 2, 3, 4]) >>> odd, even = data.where_clause(data['X'] % 2 == 1) >>> otp.run(odd) Time X 0 2003-12-01 00:00:00.000 1 1 2003-12-01 00:00:00.002 3 >>> otp.run(even) Time X 0 2003-12-01 00:00:00.001 2 1 2003-12-01 00:00:00.003 4 - Filtering based on the result of another query: - >>> another_query = otp.Tick(WHERE='mod(X, 2) = 1') >>> data = otp.Ticks(X=[1, 2, 3, 4]) >>> data, _ = data.where_clause(otp.eval(another_query)) >>> otp.run(data) Time X 0 2003-12-01 00:00:00.000 1 1 2003-12-01 00:00:00.002 3 - Using - discard_on_matchparameter to invert the condition:- >>> data = otp.Ticks(X=[1, 2, 3, 4]) >>> even, odd = data.where_clause(data['X'] % 2 == 1, discard_on_match=True) >>> otp.run(even) Time X 0 2003-12-01 00:00:00.001 2 1 2003-12-01 00:00:00.003 4 >>> otp.run(odd) Time X 0 2003-12-01 00:00:00.000 1 1 2003-12-01 00:00:00.002 3 - Using - stop_on_first_mismatchparameter to not propagate ticks after first mismatch:- >>> data = otp.Ticks(X=[1, 2, 3, 4]) >>> data, other = data.where_clause(data['X'] % 2 == 1, stop_on_first_mismatch=True) >>> otp.run(data) Time X 0 2003-12-01 1 - But other branch will contain all ticks after the mismatch, even if they don’t meet the condition: - >>> otp.run(other) Time X 0 2003-12-01 00:00:00.001 2 1 2003-12-01 00:00:00.002 3 2 2003-12-01 00:00:00.003 4 - See also