otp.format#
- format(format_line, *args, **kwargs)[source]#
Perform a string formatting operation. Currently, there are only 2 types of formatting available:
Float precision -
{:.xf}
, wherex
is number, e.g.{:.5f}
Time formatting - the same as in
Source.dt.strftime
See examples for more information.
- Parameters
format_line (str) – String which contains literal text or replacement fields delimited by braces {}. Currently content of the braces is not supported.
args – Values to paste into the line.
kwargs – Key-word values to paste into the line.
- Return type
Operation
with type equal tovarstring
Examples
It allows to format
Operation
. For example,Column
:>>> data = otp.Ticks(A=[1, 2], B=['abc', 'def']) >>> data['C'] = otp.format('A field value is `{}` and B field value is `{}`', data['A'], data['B']) >>> otp.run(data) Time A B C 0 2003-12-01 00:00:00.000 1 abc A field value is `1` and B field value is `abc` 1 2003-12-01 00:00:00.001 2 def A field value is `2` and B field value is `def`
Formatting can use positional arguments:
>>> data = otp.Ticks(A=[1, 2], B=['abc', 'def']) >>> data['C'] = otp.format('A is `{0}`, B is `{1}`. Also, A is `{0}`', data['A'], data['B']) >>> otp.run(data) Time A B C 0 2003-12-01 00:00:00.000 1 abc A is `1`, B is `abc`. Also, A is `1` 1 2003-12-01 00:00:00.001 2 def A is `2`, B is `def`. Also, A is `2`
Formatting can be used with key-word arguments:
>>> data = otp.Ticks(A=[1, 2], B=['abc', 'def']) >>> data['C'] = otp.format('A is `{a}`, B is `{b}`. Also, A is `{a}`', a=data['A'], b=data['B']) >>> otp.run(data) Time A B C 0 2003-12-01 00:00:00.000 1 abc A is `1`, B is `abc`. Also, A is `1` 1 2003-12-01 00:00:00.001 2 def A is `2`, B is `def`. Also, A is `2`
Float numbers can be formatted:
>>> data = otp.Ticks(A=[12.3456, 67.8971]) >>> data['B'] = otp.format('A is about {:.2f}', data['A']) >>> otp.run(data) Time A B 0 2003-12-01 00:00:00.000 12.3456 A is about 12.35 1 2003-12-01 00:00:00.001 67.8971 A is about 67.90
Time can be formatted:
>>> data = otp.Tick(A=otp.datetime(2020, 4, 5, 17, 56, 3, 789123)) >>> data['B'] = otp.format('A is {:%Y/%m/%d %H:%M:%S.%J}', data['A']) >>> otp.run(data) Time A B 0 2003-12-01 2020-04-05 17:56:03.789123 A is 2020/04/05 17:56:03.789123000