otp.Source.sink#
- Source.sink(ep, out_pin=None, move_node=True)#
- Appends node inplace to the source. Connect out_pin of this source to ep. Can be used to connect onetick.query objects to onetick.py source. Data schema changes (added or deleted columns) will not be detected automatically after applying sink function, so the user must change the schema himself by updating schema property. - Parameters
- ep (otq.graph_components.EpBase, otq.graph_components.EpBase.PinnedEp, Tuple[otq.graph_components.EpBase, uuid.uuid4, Optional[str], Optional[str]]) – onetick.query EP object to append to source. 
- out_pin (Optional[str], default=None) – name of the out pin to connect to ep 
- move_node (bool, default=True) – 
 
- Returns
- result – Last node of the source 
- Return type
- otq.graph_components.EpBase, otq.graph_components.EpBase.PinnedEp 
 - Examples - Adding column ‘B’ directly with onetick.query EP. - >>> data = otp.Tick(A=1) >>> data.sink(otq.AddField(field='B', value=2)) AddField(field='B',value=2) >>> otp.run(data) Time A B 0 2003-12-01 1 2 - But we can’t use this column with onetick.py methods yet. - >>> data['C'] = data['B'] Traceback (most recent call last): ... AttributeError: There is no 'B' column - We should manually change source’s schema - >>> data.schema.update(B=int) >>> data['C'] = data['B'] >>> otp.run(data) Time A B C 0 2003-12-01 1 2 2